第3章_顺序结构程序设计.ppt_第1页
第3章_顺序结构程序设计.ppt_第2页
第3章_顺序结构程序设计.ppt_第3页
第3章_顺序结构程序设计.ppt_第4页
第3章_顺序结构程序设计.ppt_第5页
已阅读5页,还剩72页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第三章顺序结构程序设计,3.1 程序的三种基本结构 3.2 C语句概述 3.3 赋值表达式和赋值语句 3.4 数据输入输出的概念及在C语言中的实现 3.5 字符数据的输入输出 3.6 简单的格式输入与输出 3.7 较复杂的输入输出格式控制 3.8 顺序结构程序设计举例,3.1 程序的三种基本结构,一个良好的程序由以下三种基本结构组成: 顺序结构:各操作步骤顺序执行,是一种最 简单的基本结构。 (2)选择结构:根据是否满足给定的条件而从两组操作中选择一种操作 (3)循环结构:在一定条件下反复执行某一部分的操作,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

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

4、,3.3 赋值表达式和赋值语句 3.3.1 赋值表达式,如果是包含若干项的表达式,则相当于它有括号。 例: 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

6、 赋值表达式和赋值语句 3.3.1 赋值表达式,分析赋值表达式: (a=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

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

10、输出格式符,而要用输出无符号数的“%u”格式符。,例:3.2 无符号整数赋值给有符号整型变量,注意数值范围。#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的补码。,转换规则: 将无符号整数赋值给长度相同的有符号整型变量时,应注意不要超出有符号整型变量的数值范围,否则会出错。,

11、3.3 赋值表达式和赋值语句 3.3.3 赋值语句,赋值语句是由赋值表达式加上一个分号构成。 赋值表达式的作用是将一个表达式的值赋给一个变量。 赋值表达式具有计算和赋值双重功能。程序中的计算功能主要是由赋值语句来完成。 语言的赋值语句与其他高级语言的赋值语句之间的差异: (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 字符串输入函

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

14、void 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 输入单个字符。#inc

15、ludevoid main() char c; c=getchar(); putchar(c); putchar(n);,运行程序:从键盘输入字符a按Enter键屏幕上将显示输出的字符aaa,字符串的输入输出,puts函数 puts函数的功能:向显示器输出字符串(输出完,换行),其一般格式为:puts(字符数组);使用该函数需要注意的是:字符数组必须以0结束。,gets函数,gets函数的功能是从键盘输入一以回车结束的字符串放入字符数组中,并自动加0 。其一般格式为:gets(字符数组)。使用gets函数需要注意的是:输入串长度应小于字符数组长度,且可以输入包含空格的字符串。,#include

16、 void main( ) char string80; printf(“Input a string:”); gets(string); puts(string); ,3.6 简单的格式输入与输出3.6.1 用简单的printf函数输出数据,printf函数(格式输出函数)的作用是向终端(或系统隐含指定的输出设备)输出若干个任意类型的数据 。 printf函数的一般格式为: printf(格式控制,输出表列) 例: printf(”%d,%cn”,i,c),3.6 简单的格式输入与输出3.6.1 用简单的printf函数输出数据,printf函数的参数包括两部分: (1)“格式控制”是用双撇

17、号括起来的字符串,也称“转换控制字符串”,它包括两种信息。 格式说明。格式说明由“”和格式字符组成,如、等。它的作用是将输出的数据转换为指定的格式输出。格式说明总是由“”字符开始的。 普通字符。普通字符即需要原样输出的字符 。例如上面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 简单的

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

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

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

21、;输出如下 1.234560 e+002 6列 5列,C编译系统自动指定给出数字部分的小数位数为位,指数部分占5位,3.6 简单的格式输入与输出3.6.2 用简单的scanf函数输入数据,scanf函数作用:按照变量在内存的地址将变量值存进去。 一般格式:scanf(格式控制,地址表列),同printf函数,是由若干个地址组成的表列,可以是变量的地址,或字符串的首地址,例3.8 用scanf函数输入数据。#includevoid main()int a,b,c;scanf(“%d%d%d”,a在内存中的地址 若: a=123,d=12345,则输出结果为: 123,12345,3.7 较复杂的

22、格式输入与输出3.7.1 输出数据格式控制, %ld。对于int型数据占2字节的系统,在输出长整型 数据时要在格式字符d前面加一个英文字毋l。 例: long 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进制整数形式输出。由于是将内存单元中 的各位的值(或)按

23、八进制形式输出,因此输出的 数值不带符号,即将符号位也一起作为八进制数的一部 分输出。 例: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); 输出结果

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

25、n()unsigned 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,65535b=-2,177776,fffe,65534,VC+6.0环境下的运行结果: a=65535,177777,ffff,65535=-2,37777777776,fffffffe,4294967294,3.7 较复杂的格式输入与输出3.7.1 输出数据格式控制,,指定输出的字符串占列。如果字符串本身长度大于,则突破

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

27、“CHINA”);,运行结果: CHINA, CH ,CHIN,CHI,例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.7 较复杂的格式输入与输出3.7.1 输出数据格式控制, m.ne和-m.ne。、和“”字符的含义与前相同。 此处指拟输出的数据的小数部分(又称尾数)的小数位数。 若,则: printf(%e %10e %10.2e %.2e

28、%-10.2e,f,f,f,f,f); 输出如下: 1.234560e+002 1.234560e+002 1.23e+002 1.23e+002 13列 13列 10列 9列 1.23e+002 10列,3.7 较复杂的格式输入与输出3.7.1 输出数据格式控制,(10)%g,用来输出实数. 它根据数值的大小,自动选格式或格式(选择输出时占 宽度较小的一种),且不输出无意义的零。 例:若,则 ( ,); 输出如下: 123.468000 1.234680e+002 123.468 10列 13列 10列,说明: 用格式输出占列,用格式输出占列,用 格式时,自动从上面两种格式中选择短者(今以格

29、式为短) 故占列,并按格式用小数形式输出,最后3个小数位为 无意义的,不输出,因此输出123.468,然后右补3个空格。 格式用得较少。,3.7 较复杂的格式输入与输出3.7. 输入数据格式控制,说明: 除了X,E,G外,其他各式字符必须用小写。 可以在printf函数中的“格式控制”字符串中包含转义字符。 一个格式说明必须以“%”开头,以9个格式字符之一为结束,中间可以插入附加格式字符。 想输出%,则应该在格式控制字符串中用连续两个%表示,3.7 较复杂的格式输入与输出3.7. 输入数据格式控制,表.scanf格式字符,3.7 较复杂的格式输入与输出3.7. 输入数据格式控制,表.scanf的附加格式说明字符,3.7 较复杂的格式输入与输出3.7. 输入数据格式控制,说明: 对unsigned型变量所需要的数据,可以用%u,%d或%o,%x格式输入。 可以根据格式字符的含义分隔字符。 可以指定输入数据所占的列数,系统自动按它截取所需数据。 如果在%后有一个“*”附加说明符,表示跳过它指定的列数。 输入数据时不能规定精度。,根据格式字符的含义分

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论