第3章最简单的C程序设计3.ppt

上传人:本田雅阁 文档编号:2254819 上传时间:2019-03-11 格式:PPT 页数:81 大小:725.01KB
返回 下载 相关 举报
第3章最简单的C程序设计3.ppt_第1页
第1页 / 共81页
第3章最简单的C程序设计3.ppt_第2页
第2页 / 共81页
第3章最简单的C程序设计3.ppt_第3页
第3页 / 共81页
亲,该文档总共81页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《第3章最简单的C程序设计3.ppt》由会员分享,可在线阅读,更多相关《第3章最简单的C程序设计3.ppt(81页珍藏版)》请在三一文库上搜索。

1、第3章 最简单的C程序设计,3.1 顺序程序设计举例 3.2 数据的表现形式及其运算 3.3 C语句 3.4 数据的输入输出,3.1顺序程序设计举例,例3.1 有人用温度计测量出用华氏法表示的温度(如 F,今要求把它转换为以摄氏法表示的温度(如 C) 。,解题思路:找到二者间的转换公式,f代表华氏温度,c代表摄氏温度,3.1顺序程序设计举例,#include int main ( ) float f,c; f=64.0; c=(5.0/9)*(f-32); printf(“f=%fnc=%fn“,f,c); return 0; ,3.1顺序程序设计举例,#include int main (

2、) float f,c; f=64.0; c=(5.0/9)*(f-32); printf(“f=%fnc=%fn“,f,c); return 0; ,定义f和c为单精度浮点型变量,指定f的值,计算c的值,输出f和c的值,3.2 数据的表现形式及其运算,3.2.1 常量和变量 3.2.2 数据类型 3.2.3 整型数据 3.2.4 字符型数据 3.2.5 浮点型数据 3.2.6 怎样确定常量的类型 3.2.7 运算符和表达式,3.2.1 常量和变量,1.常量:在程序运行过程中,其值不能被改变的量。 整型常量、实型常量、字符常量、字符串常量。 符号常量:#define PI 3.1416 例 常

3、量与符号常量的使用 #include #define PRICE 30 main ( ) int num, total; num=10; total=num * PRICE; printf(“total=%dn“,total); ,3.2.1 常量和变量,2. 变量:在程序运行期间,变量的值是可以改变的。 变量必须先定义,后使用。 定义变量时指定该变量的名字和类型。 变量名和变量值是两个不同的概念。 变量名实际上是以一个名字代表的一个存储单元。 从变量中取值,实际上是通过变量名找到相应的内存地址,从该存储单元中读取数据。 3.常变量:const int a=3;,3.2.1 常量和变量,4.标

4、识符:有效字符序列,用来标识对象的名称,如:变量名、符号常量名、 函数名、数组名、类型名等。 命名规则 : 只能由字母、数字和下划线3种字符组成,且第一个字符必须为字母或下划线。 合法的标识符:如sum,average, _total, Class, day, BASIC, li_ling 不合法的标识符:M.D.John,¥123,33,3D64,ab,注意: 1.区别大小写。 如sum与SUM为不同的变量名,但一般变量名用小写字母,符号常量采用大写字母。 2.标识符必须先定义后使用。 分配单元、 确定类型、 语法检查 3.在一个程序单元中(分程序或函数中)不能重复定义。 4.关键字(P37

5、8 附录C)不能作为标识符。 5.标识符长度无统一规定。 TC识别前8个字符student_name student_number只作为同一个变量。 6.按义取名。,3.2.2 数据类型,所谓类型,就是对数据分配存储单元的安排,包括存储单元的长度(占多少字节)以及数据的存储形式。 不同的类型分配不同的长度和存储形式。,3.2.3 整型数据,1. 整型数据的分类 最基本的整型类型 基本整型(int型):占2个或4个字节 短整型(short int):VC+6.0中占2个字节 长整型(long int):VC+6.0中占4个字节 双长整型(long long int):C99新增的,3.2.3 整

6、型数据,2. 整型变量的符号属性 整型变量的值的范围包括负数到正数。 可以将变量定义为“无符号”类型。 扩充的整形类型: 有符号基本整型 signed int; 无符号基本整型 unsigned int; 有符号短整型 signed short int; 无符号短整型 unsigned short int; 有符号长整型 signed long int; 无符号长整型 unsigned long int 有符号双长整型 signed long long int; 无符号双长整型 unsigned long long int,整数类型的有关数据:,类型 类型说明符 长度 数的范围 基本型 int

7、 2字节 -3276832767 短整型 short 2字节 -215215-1 长整型 long 4字节 -231231-1 无符号整型 unsigned 2字节 065535 无符号短整型 unsigned short 2字节 065535 无符号长整型 unsigned long 4字节 0(232-1) 注:对应不同的机器和编译系统,各类数据所占内存字节数不尽相同,因此数值范围也不同。,整型常量的三种表示形式,十进制整数。 如:123, -456。 八进制整数。以0开头的数是八进制数。 如:0123表示八进制数123,等于十进制数83,-011表示八进制数-11,即十进制数-9。 十六

8、进制整数。以0x开头的数是16进制数。 如:0x123,代表16进制数123,等于十进制数 291。 -0x12等于十进制数10。,整型数据在内存中的存放形式,数据在内存中是以二进制形式存放的,有符号数用补码表示。 如: int i,j; i=10;j=-10; 则:i存储为:0000 0000 0000 1010 j存储为:1111 1111 1111 0110,整数13在内存中实际存放的情况,例 整型变量的定义与使用,#include main ( ) int a,b,c,d; unsigned u; a=12;b=-24;u=10; c=a+u;d=b+u; printf(“a+u=%d

9、,b+u=%dn“,c,d); ,运行结果: a+u=22 b+u=-14,例 整型数据的溢出,#include main() int a,b; a=32767; b=a+1; printf(“%d,%dn“,a,b); ,运行结果: 32767,-32768,运行结果分析: 有符号整型变量的范围为-3276832767,运算结果超出此范围,发生“溢出”。 发生“溢出”时,编写的程序如果没有对此情况进行处理,则程序将根据错误的结果继续运行。,3.2.4 字符型数据,字符是按其代码(整数)形式存储的 C99把字符型数据作为整数类型的一种 字符型数据在使用上有自己的特点,3.2.4 字符型数据,1

10、.字符与字符代码 大多数系统采用ASCII字符集 字母:A Z,a z 数字:09 专门符号:29个:! ” # & ( ) *等 空格符:空格、水平制表符、换行等 不能显示的字符:空字符、警告、退格、回车等,3.2.4 字符型数据,2.字符变量 用类型符char定义字符变量 char c = ?; 系统把“?”的ASCII代码63赋给变量c printf(”%d %cn”,c,c); 输出结果是: 63 ?,3.2.4 字符型数据,字符1和整数1是不同的概念: 字符1只是代表一个形状为1的符号,在需要时按原样输出,在内存中以ASCII码形式存储,占1个字节 整数1是以整数存储方式(二进制补码

11、方式)存储的,占2个或4个字节,字符常量,1、用单引号括起来的一个字符。 a A ? 2、转义字符:以“”开头的特殊字符。 n 换行 t 水平制表 r 回车 反斜杠 ddd ddd 1到3位八进制数字(ASCII码值) xhh hh表示1到2位十六进制数字(ASCII码值) 见P40 表3.1,P377 附录B。,字符数据在内存中的存储形式及其使用方法,采用ASCII编码存放(占一个字节)。 a 97D 61H 01100001 b 98D 62H 01100010 在表示范围内可以作为整型数据使用。,例 向字符变量赋以整数,#include main() char c1,c2; c1=97;

12、 c2=98; printf(“%c %cn“,c1,c2); printf(“%d %dn“,c1,c2); ,运行结果: 97 98,3.2.5 浮点型数据,浮点型数据是用来表示具有小数点的实数。 float型(单精度浮点型) 编译系统为float型变量分配4个字节 数值以规范化的二进制数指数形式存放 参见教材图3.11 double型(双精度浮点型) 编译系统为double型变量分配8个字节 15位有效数字 long double(长双精度)型,浮点型常量的表示方法,两种表 示形式,小数 指数,0.123 3e-3,1e3、1.8e-3、-123e-6、-.1e-3 e3、2.1e3.5

13、、.e3、e,注意:字母e(或E)之前必须有数字,且e (或E)后面的指数必须为整数。,浮点型常量的表示方法,规范化的指数形式: 在字母e(或E)之前的小数部分中,小数点左边 有且只能一位非零的数字。 例如: 123.456可以表示为: 123.456e0, 12.3456e1, 1.23456e2, 0.123456e3, 0.0123456e4, 0.00123456e 如果浮点数以指数形式输出,则输出规范化的指数形式。,3.2.6 怎样确定常量的类型,字符常量:由单撇号括起来的单个字符或转义字符。 整型常量:不带小数点的数值,数字跟l或L表示长整型;跟u或U表示无符号整型。 系统根据数值

14、的大小确定int型还是long型等 浮点型常量:凡以小数形式或指数形式出现的实数 C编译系统把浮点型常量都按双精度处理(数字跟f或F表示单精度浮点型),3.2.7 运算符和表达式,1.基本的算术运算符: + :正号运算符(单目运算符) - :负号运算符(单目运算符) * :乘法运算符 / :除法运算符 % :求余运算符 + :加法运算符 - :减法运算符,3.2.7 运算符和表达式,说明 两个整数相除的结果为整数 如5/3的结果值为,舍去小数部分 如果除数或被除数中有一个为负值,舍入方向不固定。例如,-5/3,有的系统中得到的结果为-1,在有的系统中则得到结果为-2 VC+采取“向零取整”的方

15、法 如5/3=1,-5/3=-1,取整后向零靠拢 % 运算符要求参加运算的运算对象(即操作数)为整数,结果也是整数。如8%3,结果为2,课堂练习,4 / 3 = ? -4 / 3 = ? 5 / 3 = ? -5 / 3 = ? 4 % 3 = ? -4 % 3 = ? 5 % 3 = ? -5 % 3 = ?,3.2.7 运算符和表达式,2. 自增、自减运算符: 作用是使变量的值或减 +i,-i:在使用i之前,先使i的值加(减)1 i+,i-:在使用i之后,使i的值加(减)1 例如: j=+i 如果运算之前i的值为3,则运算后i的值为4,j的值也为4。 j=i+ 如果运算之前i的值为3,则运

16、算后i的值为4,j的值却为3 注意: 1.自增、自减运算不能用于常量和表达式3+,(a+b)+。 2.右结合性 -i+ 相当于-(i+)。,3.2.7 运算符和表达式,3. 算术表达式和运算符的优先级与结合性: C 算术表达式: 用算术运算符和圆括号将运算对象(也称操作数)连接起来的、符合C语法规则的式子。 运算对象: 常量、变量、函数 等。 优先级: 对于算术运算, 必须掌握其优先级具体见P378(附录D) 4、结合性: 一个运算对象两边有两个优先级相同的运算符时,该运算对象先和左边的运算符结合称左结合性,如先和右边的运算符结合称右结合性。,左右结合性: a + b + c; a = b =

17、 c;,3.2.7 运算符和表达式,4.不同类型数据间的混合运算: +、-、*、/ 运算的两个数中有一个数为float或double型,结果是double型。系统将float型数据都先转换为double型,然后进行运算 (2) 如果int型与float或double型数据进行运算,先把int型和float型数据转换为double型,然后进行运算,结果是double型 (3)字符型数据与整型数据进行运算,就是把字符的ASCII代码与整型数据进行运算,各类数值型数据间的混合运算,混合运算:字符型、整型和浮点型。在进行运算时,不同类型的数据要先转换成同一类型,然后进行运算(这种类型转换由系统自动进行

18、的)。,3.2.7 运算符和表达式,例3.3 给定一个大写字母,要求用小写字母输出。,解题思路: 关键是找到大、小写字母间的内在联系 同一个字母,用小写表示的字符的ASCII代码比用大写表示的字符的ASCII代码大32,3.2.7 运算符和表达式,#include int main ( ) char c1,c2; c1=A; c2=c1+32; printf(“%cn“,c2); printf(”%dn”,c2); return 0; ,3.2.7 运算符和表达式,#include int main ( ) char c1,c2; c1=A; c2=c1+32; printf(“%cn“,c2

19、); printf(”%dn”,c2); return 0; ,将字符A的ASCII代码65放到c1中,将65+32的结果放到c2中,用字符形式输出,用十进制形式输出,3.2.7 运算符和表达式,5. 强制类型转换运算符 强制类型转换运算符的一般形式为 (类型名)(表达式) (double)a (将转换成double类型) (int) (x+y) (将x+y的值转换成int型) (float)(5%3)(将5%3的值转换成float型) 有两种类型转换 系统自动进行的类型转换 强制类型转换,3.2.7 运算符和表达式,6.运算符 (1) 算术运算符 (+ - * / % + -) (2) 关系

20、运算符 ( !) (3) 逻辑运算符 (! |) (4) 位运算符 ( | ) (5) 赋值运算符 (及其扩展赋值运算符) (6) 条件运算符 (?:),3.2.7 运算符和表达式,6.运算符 (7) 逗号运算符 (,) (8) 指针运算符 (*和) (9) 求字节数运算符 (sizeof) (10) 强制类型转换运算符 ( (类型) ) (11) 成员运算符 (.-) (12) 下标运算符 ( ) (13) 其他 (如函数调用运算符(),3.3 C语句,3.3.1 C语句的作用和分类 3.3.2 最基本的语句-赋值语句,3.3.1 C语句的作用和分类,语句分为以下5类: (1) 控制语句:

21、if、switch、for、while、dowhile、continue、break、return、goto等 (2) 函数调用语句 (3) 表达式语句 (4) 空语句 (5) 复合语句,3.3.2 最基本的语句-赋值语句,在C程序中,最常用的语句是: 赋值语句 输入输出语句 其中最基本的是赋值语句,3.3.2 最基本的语句-赋值语句,例3.4 给出三角形的三边长,求三角形面积。 解题思路:假设给定的三个边符合构成三角形的条件 关键是找到求三角形面积的公式 公式为: 其中s=(a+b+c)/2,#include #include int main ( ) double a,b,c,s,area

22、; a=3.67; b=5.43; c=6.21; s=(a+b+c)/2; area=sqrt(s*(s-a)*(s-b)*(s-c); printf(“a=%ftb=%ft%fn“,a,b,c); printf(“area=%fn“,area); return 0; ,#include #include int main ( ) double a,b,c,s,area; a=3.67; b=5.43; c=6.21; s=(a+b+c)/2; area=sqrt(s*(s-a)*(s-b)*(s-c); printf(“a=%ftb=%ft%fn“,a,b,c); printf(“area

23、=%fn“,area); return 0; ,对边长a、b、c赋值,计算s,计算area。sqrt为数学函数,计算平方根,调用数学函数加此行,转义字符,使输出位置跳到下一个tab位置,归纳总结: 1.赋值运算符 “”是赋值运算符 作用是将一个数据赋给一个变量 也可以将一个表达式的值赋给一个变量 2.复合的赋值运算符 在赋值符“”之前加上其他运算符,可以构成复合的运算符 等价于 3.赋值表达式 一般形式为: 变量 赋值运算符 表达式 对赋值表达式求解的过程: 求赋值运算符右侧的“表达式”的值 赋给赋值运算符左侧的变量,归纳总结: 4.赋值过程中的类型转换 两侧类型一致时,直接赋值 两侧类型不一

24、致,但都是算术类型时,自动将右侧的类型转换为左侧类型后赋值 定义变量时要防止数据溢出 5.赋值表达式和赋值语句 赋值表达式的末尾没有分号,而赋值语句有分号 一个表达式可以包含赋值表达式,但决不能包含赋值语句 6.变量赋初值 int a=3,b=3,c; int a=3; 相当于 int a; a=3;,3.4 数据的输入输出,3.4.1 输入输出举例 3.4.2 有关数据输入输出的概念 3.4.3 用printf函数输出数据 3.4.4 用scanf函数输入数据 3.4.5 字符数据的输入输出,3.4.1 输入输出举例,例3.5 求 方程的根。a、b、c由键盘输入, 设 。 解题思路:首先要知

25、道求方程式的根的方法。 由数学知识已知:如果 0,则一元二次方程有两个实根:,若记,#include #include int main ( ) double a,b,c,disc,x1,x2,p,q; scanf(“%lf%lf%lf“, ,#include #include int main ( ) double a,b,c,disc,x1,x2,p,q; scanf(“%lf%lf%lf“, ,程序中调用数学函数sqrt,输入a,b,c的值,取变量地址,输入3个双精度型实数, 将值赋给后面的变量,输出实数,数据占7列, 其中小数占2列,3.4.2 有关数据输入输出的概念,几乎每一个C程序

26、都包含输入输出,输入输出是程序中最基本的操作之一。 (1) 所谓输入输出是以计算机主机为主体而言的 从计算机向输出设备(如显示器、打印机等)输出数据称为输出 从输入设备(如键盘、磁盘、光盘、扫描仪等)向计算机输入数据称为输入 (2) 语言本身不提供输入输出语句 输入和输出操作是由C标准函数库中的函数来实现的 printf和scanf不是语言的关键字,而只是库函数的名字 putchar、getchar、puts、gets (3)在使用输入输出函数时,要在程序文件的开头用预编译指令 #include 或 #include stdio.h,3.4.3 用printf函数输出数据,1.printf函数

27、的一般格式 printf(格式控制,输出表列) 例如: printf(”i=%d,c=%cn”,i,c);,格式声明,普通字符,可以是常量、变量或表达式,3.4.3 用printf函数输出数据,2. 常用格式字符 格式符。用来输出一个有符号的十进制整数 可以在格式声明中指定输出数据的域宽 printf(”%5d%5dn”,12,-345); %d输出int型数据 %ld输出long型数据,3.4.3 用printf函数输出数据,2. 常用格式字符 格式符。用来输出一个字符 char ch=a; printf(”%c”,ch); 或 printf(”%5c”,ch);,输出字符:a,3.4.3

28、用printf函数输出数据,2. 常用格式字符 格式符。用来输出一个字符串 printf(”%s”,”CHINA”); ,输出字符串:CHINA,3.4.3 用printf函数输出数据,2. 常用格式字符 f格式符。用来输出实数(包括单双精度) ,以小数形式输出 不指定数据宽度和小数位数,用%f 例3.6 用%f输出实数,只能得到位小数。 double a=1.0; printf(”%fn”,a/3);,3.4.3 用printf函数输出数据,2. 常用格式字符 f格式符。用来输出实数,以小数形式输出 指定数据宽度和小数位数。用%m.nf printf(“%20.15fn“,1/3); pri

29、ntf(“%.0fn”,10000/3.0);,3.4.3 用printf函数输出数据,2. 常用格式字符 f格式符。用来输出实数,以小数形式输出 指定数据宽度和小数位数。用%m.nf float a; a=10000/3.0; printf(“%fn“,a);,3.4.3 用printf函数输出数据,2. 常用格式字符 f格式符。用来输出实数,以小数形式输出 输出的数据向左对齐,用%-m.nf,3.4.3 用printf函数输出数据,2. 常用格式字符 f格式符。用来输出实数,以小数形式输出 float型数据只能保证6位有效数字 double型数据能保证15位有效数字 计算机输出的数字不都是

30、绝对精确有效的,3.4.3 用printf函数输出数据,2. 常用格式字符 e格式符。指定以指数形式输出实数 %e,VC+给出小数位数为位 指数部分占5列 小数点前必须有而且只有1位非零数字 printf(”%e”,123.456); 输出:1.234560 e+002,3.4.3 用printf函数输出数据,2. 常用格式字符 e格式符。指定以指数形式输出实数 %m.ne printf(”%13.2e”,123.456); 输出: 1.23e+002 (前面有4个空格),printf的格式控制的完整格式: % - 0 m.n l或h 格式字符 下面对组成格式说明的各项加以说明: %:表示格式

31、说明的起始符号,不可缺少。 -:有-表示左对齐输出,如省略表示右对齐输出。 0:有0表示指定空位填0,如省略表示指定空位不填。 m.n:m指域宽,即对应的输出项在输出设备上所占的字符数。n指精度。用于说明输出的实型数的小数位数。未指定n时,隐含的精度为n=6位。 l或h:l对整型指long型,对实型指double型。h用于将整型的格式字符修正为short型。,格式字符:格式字符用以指定输出项的数据类型和输出格式。 %d:以带符号十进制形式输出整数。 %o:以无符号八进制形式输出整数。 %x:以无符号十六进制形式输出整数。 %u:以无符号十进制形式输出整数。 %c:以字符形式输出,只输出一个字符

32、。 %s:输出字符串。 %f:以小数形式输出实数,隐含输出六位小数。 %e:以指数形式输出实数。 %g:选用%f或%e格式中输出宽度较短的一种格式,不输出无意义的0。,说明,除了X,E,G外,其他各式字符必须用小写。 可以在printf函数中的“格式控制”字符串中包含转义字符。 一个格式说明必须以“%”开头,以9个格式字符之一为结束,中间可以插入附加格式字符。 如果需要输出%,则应该在格式控制字符串中用连续两个%表示。,例 输出十进制整数。 #include main( ) int a; a=1; printf(“|%d|“,a); printf(“|%4d|“,a); printf(“|%.

33、3d|“,a);printf(“|%4.3d|“,a); printf(“|%-4d|“,a); printf(“|%04d|“,a); printf(“|%+d|n“,a); a=-12; printf(“|%d|“,a); printf(“|%4d|“,a); printf(“|%.3d|“,a);printf(“|%4.3d|“,a); printf(“|%-4d|“,a); printf(“|%04d|“,a); printf(“|%+d|n“,a); a=12345; printf(“|%d|“,a); printf(“|%4d|“,a); printf(“|%.3d|“,a);pr

34、intf(“|%4.3d|“,a); printf(“|%-4d|“,a); printf(“|%04d|“,a); printf(“|%+d|n“,a); ,3.4.4 用scanf函数输入数据,1. scanf 函数的一般形式 scanf(格式控制,地址表列),含义同printf函数,可以是变量的地址,或字符串的首地址,3.4.4 用scanf函数输入数据,2. scanf函数中的格式声明 与printf函数中的格式声明相似 以开始,以一个格式字符结束,中间可以插入附加的字符 scanf(“a=%f,b=%f,c=%f“,3.4.4 用scanf函数输入数据,3.使用scanf函数时应注意

35、的问题 scanf(”%f%f%f”,a,b,c); 错 scanf(”%f%f%f”, 1 3 2 错 a=1,b=3,c=2 对 a=1 b=3 c=2 错,3.4.4 用scanf函数输入数据,3.使用scanf函数时应注意的问题 对于scanf(”%c%c%c”, 若输入 1234a123o.26,3.4.5 字符数据的输入输出,1.用putchar函数输出一个字符 从计算机向显示器输出一个字符 putchar函数的一般形式为: putchar(c) 例3.8 先后输出BOY三个字符。 解题思路: 定义3个字符变量,分别赋以初值B、O、Y 用putchar函数输出这3个字符变量的值 ,

36、3.4.5 字符数据的输入输出,#include int main ( ) char a=B,b=O,c=Y; putchar(a); putchar(b); putchar(c); putchar (n); return 0; ,向显示器输出字符B,向显示器输出换行符,改为int a=66,b=79,c=89;,3.4.5 字符数据的输入输出,2. 用getchar函数输入一个字符 向计算机输入一个字符 getchar函数的一般形式为: getchar( ) 例3.9 从键盘输入BOY三个字符,然后把它们输出到屏幕。 解题思路: 用3个getchar函数先后从键盘向计算机输入BOY三个字符 用putchar函数输出,3.4.5 字符数据的输入输出,#include int main ( ) char a,b,c; a=getchar(); b=getchar(); c=getchar(); putchar(a); putchar(b); putchar(c); putchar(n); return 0; ,输入一个字符,送给变量a,3.4.5 字符数据的输入输出,#include int main ( ) putchar(getchar(); putchar(getchar(); putchar(getchar(); putchar(n); return 0; ,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1