第3章简单程序.ppt

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

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

1、第三章,最简单的c程序设计-顺序程序设计,主要内容,3.1 程序的三种基本结构 3.2 C语句概述 3.3 赋值表达式和赋值语句 3.4 数据输入输出的概念及在C语言 中的实现,主要内容 3.5 字符数据的输入输出 3.6 简单的格式输入与输出 3.7 较复杂的输入输出格式控制 3.8 顺序结构程序设计举例,3.1 程序的三种基本结构,一个良好的程序由以下三种基本结构组成: (1) 顺序结构:各操作步骤顺序执行,是一种最简单的基本结构。,3.2 C语句概述,C程序的结构:,3.2 C语句概述,一个c程序可以有若干个源程序文件组成 一个源文件可以有若干个函数和预处理命令以及全局变量声明部分组成

2、一个函数有函数首部和函数体组成 函数体由数据声明和执行语句组成 C语句分为,3.2 C语句概述,(一)控制语句 完成一定的控制功能 1 if() else 条件语句 6 break 中止语句 2 for() 循环语句 7 switch() 多分支选择语句 3 while()循环语句 8 return 返回语句 4 do while();循环语句 9 goto 转向语句 5 continue 结束本次循环语句,3.2 C语句概述,3.2 C语句概述,3.2 C语句概述,3.2 C语句概述,3.3 赋值表达式和赋值语句 3.3.1 赋值表达式,1.赋值运算符 赋值符号“”就是赋值运算符,它的作用是

3、将一 个数据赋给一个变量。 赋值语句是由赋值表达式加上一个分号构成 例: “a=3”,把常量赋给变量,说明:也可以将一个表达式的值赋给一个变量,3.3 赋值表达式和赋值语句 3.3.1 赋值表达式,.复合的赋值运算符 在赋值符“”之前加上其他运算符,可以构成 复合的运算符。 例: 等价于 ,先计算加,再赋给,3.3 赋值表达式和赋值语句 3.3.1 赋值表达式,可以这样理解: a += b (其中a为变量,b为表达式) a + = b(将有下划线的“a+”移到“=”右侧) | a = a + b(在“=”左侧补上变量名a) ,3.3 赋值表达式和赋值语句 3.3.1 赋值表达式,如果是包含若干

4、项的表达式,则相当于它有括号。 例: x %= y + 3 x %= (y + 3) |_ x = x %(y + 3) (不要错写成 x = x % y + 3 ),3.3 赋值表达式和赋值语句 3.3.1 赋值表达式,说明: 凡是二元(二目)运算符,都可以与赋值符一起组合成复合赋值符。有关算术运箅的复合赋值运算符有:,*, 语言采用这种复合运算符,一是为了简化程序,使程序精练,二是为了提高编译效率,能产生质量较高的目标代码。,3.3 赋值表达式和赋值语句 3.3.1 赋值表达式,3.赋值表达式 由赋值运算符将一个变量和一个表达式连接起 来的式子。 一般形式为:变量 赋值运算符 表达式 赋值

5、表达式的求解过程:先求赋值运算符右侧的“ 表达式”的值,然后赋给赋值运算符左侧的变量。 赋值运算符左侧的标识符称为“左值” 出现在赋值运算符右侧的表达式称为“右值” 注意:并不是任何对象都可以作为左值的,表达式和常变量就不能作为左值。任何左值都可做右值。,3.3 赋值表达式和赋值语句 3.3.1 赋值表达式,说明:赋值运算符按照“自右而左” 的结合顺序,因此,“a=(b=5)”和 “a=b=5”等价,赋值表达式中的“表达式”,又可以是一个赋值表达式。 例:a=(b=5) 相当于执行“b=5”和“ab”两 个赋值表达式,3.3 赋值表达式和赋值语句 3.3.1 赋值表达式,分析赋值表达式: (a

6、=3*5)=4*3,赋值表达式为左值,右值,说明:先执行括号内的运算,将15赋给a,然后执行4*3的运算,得12,再把12赋给a。最后a的值为12,整个表达式的值为12。 注意:赋值表达式作为左值时应加括号,3.3 赋值表达式和赋值语句 3.3.1 赋值表达式,求解步骤如下: 先进行“*”的运算, 它相当于: *,a的值为144132。 再进行“”的运算,相当于: =a+(-132),a的值为132-132-264。 ,赋值表达式也可以包含复合的赋值运算符。 例: a+=a-=a*a,3.3 赋值表达式和赋值语句 3.3.1 赋值表达式,赋值表达式作为表达式的一种,不仅可以出现在赋值语句中,而

7、且可以以表达式形式出现在其他语句(如输出语句、循环语句等)中 。 例:,printf(%d,a=b);,3.3 赋值表达式和赋值语句 3.3.2 赋值过程中的类型转换,如果赋值运算符两侧的类型一致,则直接进行赋值。 例:i=6 (假设i已定义为int型) 如果赋值运算符两侧的类型不一致,但都是数值型或字符型时,在赋值时要进行类型转换。类型转换是系统自动进行的。,3.3 赋值表达式和赋值语句 3.3.2 赋值过程中的类型转换,转换规则: 将浮点型数据(包括单、双精度)赋给整型变量时,先对浮点数取为整,然后赋予整型变量。 将整型数据赋给单、双精度变量时,数值不变,但以浮点数形式存储到变量中。 将一

8、个double型数据赋给float变量时,截取其前面7位有效数字,存放到float变量的存储单元(4个字节)中。但应注意数值范围不能溢出;将一个float型数据赋给double变量时,数值不变,有效位数扩展到16位,在内存中以8个字节存储。,转换规则: 字符型数据赋给整型变量时,将字符的ASCII码赋给整型变量。 将一个占字节多的整型数据赋给一个占字节少的整型变量/字符变量时,只将其低字节原封不动地送到该变量 例:i=289; /* 已定义i为整型变量 */ c=a; /* 已定义c为字符变量 */ c=i; /* 将一个占2字节的int型数据赋给char型变量 */ i=289 c=33 将

9、有符号整数赋值给长度相同的 无符号整型变量时,按字节原样赋值。,注意:要避免进行这种赋值,因 为赋值后数值可能发生失真。如 果一定要进行这种赋值,应当保 证赋值后数值不会发生变化。,例3.1有符号整数赋值给无符号整型变量, 数据会失真。 #include void main ( ) unsigned a; /* 定义a为无符号整型变量 */ int b; /* 定义b为有符号整型变量 */ b=-1; b a=b; a printf(“%un“,a); ,运行结果:4294967295,说明:由于a是无符号整型变量,因此不能用%d 输出格式符,而要用输出无符号数的“%u”格式符。,例:3.2

10、无符号整数赋值给有符号整型变量,注意数值范围。 #include void main ( ) unsigned a; int b; a=65535; /* 两个字节16位全为1 */ b=a; /* b的数值范围为-3276832767 */ printf(“%dn“,b); ,运行结果 -1,说明:执行“b=a”时,将a的两个字节(全1)赋给b,由于是有符号的整型数,笫1个二进位是1表示此数是一个负数,16位全1是-1的补码。,转换规则: 将无符号整数赋值给长度相同的有符号整型变量时,应注意不要超出有符号整型变量的数值范围,否则会出错。,3.3 赋值表达式和赋值语句 3.3.3 赋值语句,赋

11、值语句是由赋值表达式加上一个分号构成。 赋值表达式的作用是将一个表达式的值赋给一个变量。 赋值表达式具有计算和赋值双重功能。程序中的计算功能主要是由赋值语句来完成。 语言的赋值语句与其他高级语言的赋值语句之间的差异: (1) 语言中的赋值号“”是一个运算符,在其他大多数语言中赋值号不是运算符。 (2) 要区别赋值表达式和赋值语句。其他多数高级语言没有“赋值表达式”这一概念。,3.3 赋值表达式和赋值语句 3.3.4 变量赋初值,程序中对变量赋初值的方法有两种 在定义变量的同时使变量初始化(更方便) int a=3; * 指定为整型变量,初值为 * float f=3.56; * 为浮点型变量,

12、初值.56 * char c=a; * 指定为字符变量,初值为a * 用赋值语句对变量赋值 int a; * 指定为整型变量* ; * 赋值语句,将赋给*,3.4 数据输入输出的概念 及在C语言中的实现,(一).所谓输入输出是以计算机主机为主体而言的 输出:从计算机向外部输出设备(显示器,打印机) 输出数据 输入:从输入设备(键盘,鼠标,扫描仪)向计算机 输入数据.,(二).C语言本身不提供输入输出语句,输入和输出操作是由C函数库中的函数来实现的 例如: 字符输入函数: getchar字符输出函数:putchar 格式输入函数: scanf 格式输出函数: printf 字符串输入函数:get

13、s 字数穿输出函数:puts,3.4 数据输入输出的概念 及在C语言中的实现,(三).在使用系统库函数时,要用预编译命令“#include”将有关的“头文件”包括到用户源文件中。 例如:在调用标准输入输出库函数时,文件开头应该有: #include “stdio.h” 或: #include ,头文件,3.4 数据输入输出的概念 及在C语言中的实现,3.5 字符数据的输入输出 3.5.1 用putchar函数输出一个字符,putchar函数(字符输出函数)的作用是向终端输出一个字符。 一般形式为 putchar(c) ,可以是字符型变量或整型变量,例3.3 输出单个字符。 #include v

14、oid main() char a,b,c; a=B;b=O;c=Y; putchar(a);putchar(b);putchar(c);putchar(n); ,运行结果:BOY,putchar(a);putchar(n);putchar(b);putchar(n);putchar(c);putchar(n);,运行结果:B O Y,3.5 字符数据的输入输出 3.5.2 用getchar函数输入一个字符,getchar函数(字符输入函数)的作用是从计算机终端输入一个字符。 getchar函数没有参数,一般形式为 getchar(),函数的值就是从输入设备得到的字符,例3.4 输入单个字符。

15、 #include void main() char c; c=getchar(); putchar(c); putchar(n); ,3.6 简单的格式输入与输出 3.6.1 用简单的printf函数输出数据,printf函数(格式输出函数)的作用是向终端(或系统隐含指定的输出设备)输出若干个任意类型的数据 。 printf函数的一般格式为: printf(格式控制,输出表列) 例: printf(”%d,%cn”,i,c),3.6 简单的格式输入与输出 3.6.1 用简单的printf函数输出数据,printf函数的参数包括两部分: (1)“格式控制”是用双撇号括起来的字符串,也称“转换控

16、制字符串”,它包括两种信息。 格式说明。格式说明由“”和格式字符组成,如、等。它的作用是将输出的数据转换为指定的格式输出。格式说明总是由“”字符开始的。 普通字符。普通字符即需要原样输出的字符 。例如上面printf函数中双撇号内的逗号、空格和 换行符。 (2) “输出表列”是需要输出的一些数据,可以是常量、变量或表达式。,3.6 简单的格式输入与输出 3.6.1 用简单的printf函数输出数据,printf函数的例子: printf(“a=%d b=%d”,a,b) | | | | | 格式说明 输出表列,若a=3,b=4 输出为 a=3 b=4,3.6 简单的格式输入与输出 3.6.1

17、用简单的printf函数输出数据,基本的格式字符 有以下几种:,格式符。按十进制整型数据的实际长度输出。, i格式符。作用与格式符相同,按十进制整 型数据的实际长度输出。一般习惯用%d而少用%i。,格式符。用来输出一个字符。,一个值在范围内的整数,也可以用“”使之按字符形式输出,例3.5 字符数据的输出。 #include void main() char c=a; int i=97; printf(“%c,%dn“,c,c); printf(“%c,%dn“,i,i); ,运行结果:, ,,格式符,用来输出一个字符串。 例: printf (,N); 输出字符串“N”(不包括双引号) 格式符

18、。用来输出实数(包括单、双精度) ,以小数形式输出,不指定整个字段的长度,由 系统自动指定。一般的处理方法是:整数部分全 部输出,并输出位小数。,3.6 简单的格式输入与输出 3.6.1 用简单的printf函数输出数据,注意:在输出的数字中并非全部数字都是有效数字 。单精度实数的有效位数一般为6-位,双精度实 数的有效位数一般为15-16位。,例3.6 输出实数时的有效位数。 #include void main() float x,y; x=111111.111;y=222222.222; printf(“%fn“,x+y); ,运行结果: .,结果中只有前七位是有 效数字。由于x和y是单

19、 精度变量,所以x+y也只 能保证7位的精度,后面 几位是没有意义的。,例3.7 输出双精度数时的有效位数。 #include void main() double x,y; x=11111111.11111111; y=22222222.22222222; printf(“%fn“, x+y); ,运行结果: 33333333.33333,x和y是双精度变量,能提供16位精度,但是由于用%f格式输出,只能输出6位小数 ,有两位 被省掉了。,3.6 简单的格式输入与输出 3.6.1 用简单的printf函数输出数据,(6)格式符,用格式说明 指定以指数形式输出实数。 例:printf(,123

20、.456);输出如下 1.23460 e+002 6列 5列,C编译系统自动指定给出数字部分的小数位数为位,指数部分占5位,3.6 简单的格式输入与输出 3.6.2 用简单的scanf函数输入数据,scanf函数作用:按照变量在内存的地址将变量值存进去。 一般格式:scanf(格式控制,地址表列),同printf函数,是由若干个地址组成的表列,可以是变量的地址,或字符串的首地址,例3.8 用scanf函数输入数据。 #include void main() int a,b,c; scanf(“%d%d%d”, ,a在内存中的地址 &是地址运算符,输入数据时,在两 个数据之间以一个或多个空格间隔

21、,也可以用Enter键、 T键。,3.6 简单的格式输入与输出 3.6.2 用简单的scanf函数输入数据,scanf函数的格式说明与printf函数的相似,以开 始,以一个格式字符结束,中间可插入附加的字符。 例: scanf(”%d%d%d”. /* 格式控制字符串中包含格式说明符以外的字符 */,3.6 简单的格式输入与输出 3.6.2 用简单的scanf函数输入数据,说明: scanf函数中的“格式控制”后面应当是变量地址,而不应是 变量名。 (2) 如果在“格式控制”字符串中除了格式说明以外还有其他字 符,则在输入数据时在对应位置应输入与这些字符相同的字符。 (3) 在用“”格式输入

22、字符时,空格字符和“转义字符”都 作为有效字符输入。 (4)在输入数据时,空格, “回车”、“跳格”(Tab)键或遇 非法输入,认为该数据结束。 (5) 对型变量所需的数据,可以用%u或%d格式 输入。,3.7 较复杂的格式输入与输出 3.7.1 输出数据格式控制,除了上节所介绍的基本的格式控制外,还可以用下面一些格式符和附加字符。 。为指定的输出字段的宽度。如果数据的位数小于,则左端补以空格,若大于,则按实际位数输出。 例: printf (“%4d,%4d,a,b”); 若: a=123,d=12345,则输出结果为: 123,12345,3.7 较复杂的格式输入与输出 3.7.1 输出数

23、据格式控制, %ld。对于int型数据占2字节的系统,在输出长整型 数据时要在格式字符d前面加一个英文字毋l。 例: lang a=135790; /* 定义a为长整型变量*/ printf(“%ld,a);,%d只适用于范围为-3276832767的整型数据,超过此范围的整数,应该用%ld输出,说明:如果用的是VC+ 6.0, 由于int型和long型数据都分配4 个字节,因此用%d可以输出int 和long型数据,不必要用%ld。,3.7 较复杂的格式输入与输出 3.7.1 输出数据格式控制, %。以8进制整数形式输出。由于是将内存单元中 的各位的值(或)按八进制形式输出,因此输出的 数值

24、不带符号,即将符号位也一起作为八进制数的一部 分输出。 例:int a=-1; printf(“%d,%o“,a,a); 在内存单元中的存放形式(以补码形式存放)如下: 输出为: ,,用%d输出的结果,1,111,111,111,111,111 | | | | | | 1 7 7 7 7 7 二进数111就是8进数7。因此上面的数用8进制数表示为17777,3.7 较复杂的格式输入与输出 3.7.1 输出数据格式控制, %。以16进制数形式输出整数。同样不会 出现负的十六进制数。 例: int a= -1; printf(“%x,%o,%d”,a,a,a); 输出结果为 ffff,177777

25、,-1 同样可以用 “%1x”输出长整型数,也可以指定 输出字段的宽度,如“%12x”。,3.7 较复杂的格式输入与输出 3.7.1 输出数据格式控制, %。用来输出无符号(unsigned)型数据,以十进制整数形式输出。一个有符号整数(int型)也可以用%u格式输出;反之,一个unsigned型数据也可以用%d格式输出。按相互赋值的规则处理。unsigned型数据也可用%o或%x格式输出。 c。用来指定输出字符数据的宽度m 如果有printf(“%3c”,c); 则输出“ a”,即变量输出占列,前列补空格。,例3.9 无符号数据的输出。 #include void main() unsign

26、ed int a=65535;int b=-2; printf(“a=%d,%o,%x,%un”,a,a,a,a); printf(“b=%d,%o,%x,%un”,b,b,b,b); ,Turbo C 2.0环境下的运行结果: a=-1,177777,ffff,65535 b=-2,177776,fffe,65534,VC+6.0环境下的运行结果: a=65535,177777,ffff,65535 =-2,37777777776,fffffffe,4294967294,3.7 较复杂的格式输入与输出 3.7.1 输出数据格式控制,,指定输出的字符串占列。如果字符串本身长度大于,则突破的限制

27、,将字符串全部输出。若串长小于,则左补空格。 -,如果串长小于,则在列范围内,字符串向左靠,右补空格。 -.n,输出占列,但只取字符串中左端个字符。这个字符输出在列的右侧,左补空格。 .,其中、含义同上,个字符输出在列范围的左侧,右补空格。如果,则自动取值,即保证个字符正常输出。 .,指定输出的实数共占列,其中有位小数。如果数值长度小于,则左端补空格。 .与.基本相同,只是使输出的数值向左端靠,右端补空格。,例3.10 字符串的输出。 #include void main() printf(“%3s,%7.2s,%.4s,%-5.3sn”, “CHINA”, “CHINA”, “CHINA”,

28、 “CHINA”); ,例3.11 输出实数时指定小数位数。 #include void () float f=123.456; printf(“%f %10f %10.2f %.2f% -10.2fn” ,f,f,f,f,f); ,运行结果: 123.456001 123.456001 123.46 123.46 123.46,例3.12求3个圆的周长,输出结果时上下按小数点对齐,取两位小数。 #include #define PI 3.1415926 void main ( ) double r1=1.53,r2=21.83,r3=123.71,s1,s2,s3; s1=2.0*PI*r1

29、; s2=2.0*PI*r2; s3=2.0*PI*r3; printf(“r1=%10.2fnr2=%10.2fnr3=%10.2fn“,r1,r2,r3); ,运行结果: r1= 1.53 r2= 21.83 r3= 123.71,3.7 较复杂的格式输入与输出 3.7.1 输出数据格式控制, m.ne和-m.ne。 、和“”字符的含义与前相同。 此处指拟输出的数据的小数部分(又称尾数)的小数位数。 若,则: printf(“%e %10e %10.2e %.2e %-10.2e“,f,f,f,f,f); 输出如下: 1.234560e+002 1.234560e+002 1.23e+00

30、2 1.23e+002 13列 13列 10列 9列 1.23e+002 10列,说明: 未指定,自动使. 超过给定的列,乃突破列的限制,按实际长度输出。 第3个数据共占列,小数部分占列。 只指定,未指定,自动使等于数据应占的长度。 第5个数据应占列,数值只有列,由于是“”, 数值向左靠,右补一个空格。 (注:有的C系统的输出格式与此略有不同),3.7 较复杂的格式输入与输出 3.7.1 输出数据格式控制,(10)%g,用来输出实数. 它根据数值的大小,自动选格式或格式(选择输出时占 宽度较小的一种),且不输出无意义的零。 例:若,则 ( ,); 输出如下: 123.468000 1.2346

31、80e+002 123.468 10列 13列 10列,说明: 用格式输出占列,用格式输出占列,用 格式时,自动从上面两种格式中选择短者(今以格式为短) 故占列,并按格式用小数形式输出,最后3个小数位为 无意义的,不输出,因此输出123.468,然后右补3个空格。 格式用得较少。,3.7 较复杂的格式输入与输出 3.7. 输入数据格式控制,说明: 除了X,E,G外,其他各式字符必须用小写。 可以在printf函数中的“格式控制”字符串中包含转义字符。 一个格式说明必须以“%”开头,以9个格式字符之一为结束,中间可以插入附加格式字符。 想输出%,则应该在格式控制字符串中用连续两个%表示,3.7

32、较复杂的格式输入与输出 3.7. 输入数据格式控制,表. scanf格式字符,3.7 较复杂的格式输入与输出 3.7. 输入数据格式控制,表. scanf的附加格式说明字符,3.7 较复杂的格式输入与输出 3.7. 输入数据格式控制,说明: 对unsigned型变量所需要的数据,可以用%u,%d或%o,%x格式输入。 可以指定输入数据所占的列数,系统自动按它截取所需数据。 如果在%后有一个“*”附加说明符,表示跳过它指定的列数。 输入数据时不能规定精度。,例3.13 输入三角形的三边 长,求三角形面积。 假设:三个边长a,b,c能构 成三角形。 已知面积公式: area= s=(a+b+c)/

33、2,3.8 顺序结构程序设计举例,#include #include void main() float a,b,c,s,area; scanf(“%f,%f,%f,数学函数库 因为要用到其中的sqrt函数,printf(“a=%7.2fnb=%7.2fnc=%7.2fnarea=%7.2fn“,a,b,c,area);,例3.14 从键盘输入一个大写字母,要求改用小写字母输出。 #include void main() char c1,c2; c1=getchar(); printf(“%c,%dn“,c1,c1); c2=c1+32; printf(“%c,%dn“,c2,c2); ,运行

34、情况: , ,,例3.14 从键盘输入一个大写字母,要求改用小写字母输出。 #include void main() char c1,c2; c1=getchar(); printf(“%c,%dn“,c1,c1); c2=c1+32; printf(“%c,%dn“,c2,c2); ,运行情况: , ,,3.8 顺序结构程序设计举例,例3.15 求x2方程的根。 a,b,c由键盘输入,设 。 众所周知,一元二次方程式的根为 x1= x2= 可以将上面的分式分为两项: p= , q= x1=p+q, x2=p-q,#include #include void main ( ) float a,b,c,disc,x1,x2,p,q; scanf(“a=%f,b=%f,c=%f“, ,运行情况: , ,

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

当前位置:首页 > 其他


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