C语言程序设计(谭浩强版)第四章_第1页
C语言程序设计(谭浩强版)第四章_第2页
C语言程序设计(谭浩强版)第四章_第3页
C语言程序设计(谭浩强版)第四章_第4页
C语言程序设计(谭浩强版)第四章_第5页
已阅读5页,还剩56页未读 继续免费阅读

下载本文档

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

文档简介

1、第四章第四章 顺序结构程序设计顺序结构程序设计4.1 C语句概述语句概述4.2 赋值语句赋值语句4.3 数据输入输出的概念及在数据输入输出的概念及在c语言中的语言中的实现实现4.4 字符数据的输入输出字符数据的输入输出4.5 格式输入与输出格式输入与输出4.6 顺序结构程序设计举例顺序结构程序设计举例4.1 C语句概述C程序源程序文件1源程序文件2源程序文件n.预处理命令全局变量声明函数1函数2函数n函数首部函数体变量声明执行部分(语句)一、C程序的组成 4.1 C语句概述 l一个c程序可以有若干个源程序文件组成l一个源文件可以有若干个函数和预处理命令以及全局变量声明部分组成l一个函数有函数首

2、部和函数体组成l函数体由数据声明和执行语句组成lC语句分为控制语句函数调用语句表达式语句空语句复合语句程序的语句程序的语句 4.1 C语句概述 (一)控制语句 控制语句用于控制程序的流程, 以实现程序的各种结构方式。可分成以下三类:条件判断语句,循环执行语句,转向语句1 if() else 条件语句条件语句 6 break 间断语句间断语句 2 for() 循环语句循环语句 7 switch() 开关语句开关语句3 while()循环语句循环语句 8 goto 转向语句转向语句 4 do while();循环语句循环语句 9 return 返回语句返回语句5 continue 继续语句继续语句

3、 4.1 C语句概述 (二)函数调用语句 一个函数调用加一个分号构成一个语句其一般形式为: 函数名(实际参数表); 执行函数语句就是调用函数体并把实际参数赋予函数定义中的形式参数,然后执行被调函数体中的语句,求取函数值。或完成函数的功能。例如: 调用库函数,输出字符串。 printf (This is a C statement. ); 4.1 C语句概述 (三)表达式语句 一个表达式加一个分号构成一个语句 执行表达式语句就是计算表达式的值。 例如: 赋值表达式+分号=表达式语句 a = 3 ; 自增1语句,i值增1 i+; 4.1 C语句概述 (四)空语句 只有一个分号的语句 (什么也不做)

4、(什么也不做)l用来做流程的转向点用来做流程的转向点l用来作为循环语句中的循环体用来作为循环语句中的循环体 4.1 C语句概述 (五)复合语句 用一对 括起来的语句。在程序中应把复合语句看成是单条语句,而不是多条语句, z=x+y;t=z/100;printf(“%f”,t); 4.2 赋值语句赋值语句是由赋值表达式再加分号构成的表达式语句。 其一般形式为: 变量=表达式; 赋值语句的功能和特点都与赋值表达式相同。 它是程序中使用最多的语句之一。在赋值语句的使用中需要注意以下几点: 1. 赋值符“=”右边的表达式也可以又是一个赋值表达式,因此,下述形式 变量=(变量=表达式); 是成立的,从而

5、形成嵌套的情形。其展开之后的一般形式为: 变量=变量=表达式; 例如: a=b=c=d=e=5;按照赋值运算符的右接合性,因此实际上等效于: e=5; d=e; c=d; b=c; a=b; 2. 注意在变量说明中给变量赋初值和赋值语句的区别。给变量赋初值是变量说明的一部分,赋初值后的变量与其后的其它同类变量之间仍必须用逗号间隔,而赋值语句则必须用分号结尾。 3. 在变量说明中,不允许连续给多个变量赋初值。 如下述说明是 错误的: int a=b=c=5; 必须写为: int a=5,b=5,c=5; 而赋值语句允许连续赋值。 4. 注意赋值表达式和赋值语句的区别。赋值表达式是一种表达式,它可

6、以出现在任何允许表达式出现的地方,而赋值语句则不能。 下述语句是合法的: if(x=y+5)0) z=x; 语句的功能是,若表达式x=y+5大于0则z=x。下述语句是非法的: if(x=y+5;)0) z=x; 因为x=y+5;是语句,不能出现在表达式中。 4.3 数据输入输出的概念及在数据输入输出的概念及在C 语言中的实现语言中的实现内存RAM从键盘将数据输入从数据文件读入将数据输出到屏幕将数据输出到文件数据输入数据输入/输出是相对计算机内存输出是相对计算机内存一、数据输入一、数据输入/输出的概念输出的概念二、C语言本身不提供输入输出语句,输入和输出操作是由C函数库中的函数来实现的。例如例如

7、: :字符输入函数: getchar 字符输出函数:putchar格式输入函数: scanf 格式输出函数: printf字符串输入函数:gets 字数穿输出函数:puts(三)在使用系统库函数时,要用预编译命令“#include”将有关的“头文件”包括到用户源文件中。例如:在调用标准输入输出库函数时,文件开头应该有: #include “stdio.h” 或: #include 4.4 字符数据的输入输出字符数据的输入输出(一)字符输出函数l一般形式:putchar(c) l函数作用:向终端输出一个字符 字符型变量整型变量例4.1 输出单个字符。#includevoid main()char

8、 a, b, c;a=B;b=O;c=Y;putchar(a);putchar(b);putchar(c);putchar(n);putchar(a); putchar(n); putchar(b); putchar(n); putchar(c); putchar(n); (二)字符输入函数l一般形式:getchar() l函数作用:从终端(或系统隐含指定的输入设备)输入一个字符。l函数值: 从输入设备得到的字符。l该函数是缓冲输入函数,需要等按下回车键才开始执行。例4.2 输入单个字符。#includevoid main() char c; c=getchar();putchar(c); p

9、utchar(n);控制台输入输出函数:(使用时需要包含头文件)1。从键盘输入一个字符getch( )与getchar( )作用一样,区别有两点:(1)没有屏幕回显,(2)直接响应不需要缓冲2。向屏幕输出一个字符putch(c)与putchar( )用法一样例4.2修改: 输入单个字符。#include#includevoid main() char c; c=getch();putch(c); putch(n); 4.5 格式输入与输出格式输入与输出(一)格式输出函数函数作用:向终端(或系统隐含指定的输出设备)输出若干个任意类型的数据。一般格式:printf(格式控制,输出表列)格式说明字符

10、串的一般形式为: % flags width .prec F|N|h|l|L type_char注意: 1. 格式控制可由格式字符串和非格式字符串两种组成,格式说明字符串是以%开头的字符串,其中字符串用于指定输出格式。 2. 在%后面跟有各种格式字符,以说明输出数据的类型、形式、长度、小数位数等。 3. 非格式字符串在输出时照原样输出。 4. 输出表列中给出了各个输出项, 要求格式字符串和各输出项在数量和类型上应该一一对应。1.类型类型 (type_char)%d: 以带符号的十进制形式输出整数%o: 以八进制无符号形式输出整数%x: 以十六进制无符号形式输出整数%u: 以无符号十进制形式输出

11、整数%c: 以字符形式输出,只输出一个字符%s: 输出字符串%f: 以小数形式输出浮点数,隐含输出六位小数%e: 以指数形式输出浮点数%g: 选用%f或%e格式中输出宽度较短的一种格式,不输出无意义的02.标志标志 (flag)标志字符为-、+、#、空格四种,其意义如下所示: - 结果左对齐,右边填空格 + 输出符号(正号或负号)空格 输出值为正时冠以空 格,为负时冠以负号 # 对c,s,d,u类无影响;对o类, 在输出时加前缀0;对x类,在输出时加前缀0 x;对e,g,f 类当结果有小数时才给出小数点(省略) 结果右对齐,左边填空格或03.输出最小宽度输出最小宽度(width) 用十进制整数

12、来表示输出的最少位数。 若实际位数多于定义的宽度,则按实际位数输出, 若实际位数少于定义的宽度则补以空格或0。 n至少输出n个字符,如果少于n个字符,则用空格补足0n至少输出n个字符,如果少于n个字符,则用左边用0补足4.精度精度 精度格式符以“.”开头,后跟十进制整数。本项的意义是:如果输出数字,则表示小数的位数;如果输出的是字符, 则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。(省略)对于d/i/o/u/x/X 格式,值为1对于f/e/E 格式,值为6对于g/G 格式,输出所有有效数字对于s 格式,输出直到第一个非空字符对于c 格式,无效.0对于f/e/E 格式,不

13、输出小数部分.n对于s 格式,输出n个字符对于f/e/E 格式,输出n位小数部分5.长度修饰长度修饰(h|l|L ) 用来修饰变量类型修饰 类型说明hd i o u x X短整数short intld i o u x X长整数long intle E f g GdoubleLe E f g Glong doubleLd i o u x X64位整数 _int64hc C单字节字符lc C宽字符(两个字节)hs S单字节字符串ls S宽字符串 格式符格式符。用来输出十进制整数。几种用法: d:按十进制整型数据的实际长度输出。 md: m为指定的输出字段的宽度。如果数据的位数小于m, 则左端补以空

14、格,若大于m,则按实际位数输出。 例: printf(d,d,a,b); 若a123,b12345,则输出结果为 123,12345 ld:输出长整型数据。 例: long a135790;/* 定义a为长整型变量*/ printf (ld,a);(2) 格式符格式符。以八进制整数形式输出。输出的数值不带符号,符号位也一起作为八进制数的一部分输出。例:int a=-1; printf(%d,%o,a,a); 在内存单元中的存放形式(以补码形式存放)如下: 1111111111111111 输出为: ,不会输出带负号的八进制整数。对长整数(型)可以用“”格式输出。还可以指定字段宽度。例: pri

15、ntf(o,); 输出为: 177777。 (数字前有2个空格)(3)格式符格式符。以十六进制数形式输出整数。同样不会出现负的十六进制数。例: int ; printf(,); 输出结果为: ffff,可以用“l”输出长整型数,也可以指定输出字段的宽度。例: “12”(4)格式符格式符,用来输出unsigned型数据。一个有符号整数(int型)也可以用格式输出;一个unsigned型数据也可以用格式输出;unsigned型数据也可用或格式输出。输出时按内存的二进制码做相应的解释。无符号数 按原码解释有符号数按补码解释(5)格式符格式符,用来输出一个字符。如:chard;printf (%c ,

16、 d) ;输出字符一个整数,可以用 “%c” 使之按字符形式输出。在输出前,系统会将它的值截断到范围内,作为ASCII码转换成相应的字符;一个字符数据也可以用整数形式输出。 例4.3 无符号数据的输出。#includevoid main()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);运行结果:a=-1,177777,ffff,65535b=-2,177776,fffe,65534例4.4 字符数据的输出。#includevoid main()cha

17、r c=a;int i=97;printf(“%c,%dn”, c, c);printf(“%c,%dn”, i, i); (6)s格式符格式符 输出字符串. %s。例如: printf(%s, CHINA ); 输出字符串“CHINA”(不包括双引号)。 %ms,输出的字符串占m列,若串长大于m,则全部输出,若串长小于m,则左补空格。 %-ms,若串长小于m,字符串向左靠,右补空格。 %m. ns, 输出占m列,只取字符串中左端n个字符,输出在m列的右侧,左补空格。 %-m.ns,n个字符输出在m列的左侧,右补空格,若nm,m自动取n值。例4.5字符串的输出。#includevoid mai

18、n()printf (%3s,%7.2s,%.4s,%-5.3sn,CHINA, CHINA, CHINA, CHINA, CHINA); 运行结果:CHINA, CH ,CHIN,CHI (7)格式符。格式符。用来以小数形式输出实数(包括单双精度)有以下几种用法: %f 不指定字段宽度,由系统自动指定字段宽度,使整数部分全部输出,并输出位小数。应当注意,在输出的数字中并非全部数字都是有效数字。单精度实数的有效位数一般为位。%m.nf 指定输出的数据共占列,其中有位小数。如果数值长度小于,则左端补空格。%-m.nf 与%m.nf基本相同,只是使输出的数值向左端靠,右端补空格。 例4.6 输出实

19、数时的有效位数。#include void main()float x, y;x = 111111.111;y = 222222.222;printf ( %fn, x + y ); 运行结果:. 例4.7输出双精度数时的有效位数。#include void main()double x, y;x = 1111111111111.111111111;y = 2222222222222.222222222;printf ( %fn,x+y);运行结果:3333333333333.333000 例4.8 输出实数时指定小数位数。#include void main() float f=123.45

20、6; printf(“%f%10f%10.2f%.2f%-10.2fn”,f,f,f,f,f);运行结果:123.455994 123.455994 123.46 123.46 123.46 (8)格式符格式符,以指数形式输出实数。可用以下形式: %e。不指定输出数据所占的宽度和数字部分的小数位数.例: printf(%e,123.456);输出: 2+6列 5列所输出的实数共占列宽度。(不同系统的规定有不同) m.ne和-m.ne。、和“”字符的含义与前相同。此处指拟输出的数据的小数部分(又称尾数)的小数位数。若,则:printf(%e %10e %10.2e %.2e %-10.2e,f,

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

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

23、字符串中用连续两个%表示。(二).格式输入函数l函数作用:按照变量在内存的地址将变量值存 进去。l一般格式:scanf(格式控制,地址表列)类似类似printf函数函数是由若干个地址组成的表列,可以是由若干个地址组成的表列,可以是变量的地址,或字符串的首地址是变量的地址,或字符串的首地址例4.9 用scanf函数输入数据。#includevoid main()int a,b,c;scanf(“%d%d%d”, &a, &b, &c);printf(“%d,%d,%dn”, a, b, c);运行情况:3 4 5 (输入a,b,c的值)3,4,5 (输出a,b,c的值)s

24、canf 的格式字符串 格式字符串的一般形式为: %*输入数据宽度长度类型 其中有方括号的项为任选项。各项的意义如下:1. 类型 表示输入数据的类型,其格式符和意义如下所示: d 输入十进制整数 o 输入八进制整数 x 输入十六进制整数 u 输入无符号十进制整数 f或e 输入实型数(用小数形式或指数形式) c 输入单个字符 s 输入字符串2. “*”符 用以表示该输入项读入后不赋予相应的变量,即跳过该输入值。 如 scanf(%d %*d %d,&a,&b);当输入为:1 2 3 时,把1赋予a,2被跳过,3赋予b。3.宽度 用十进制整数指定输入的宽度(即字符数)。 例如: s

25、canf(%5d,&a); 输入: 12345678 只把12345赋予变量a,其余部分被截去。 又如: scanf(%4d%4d,&a,&b);输入:12345678将把1234赋予a,而把5678赋予b。4.长度修饰 长度格式符为l和h,l表示输入长整型数据(如%ld) 和双精度浮点数(如%lf)。h表示输入短整型数据。说明:l对unsigned型变量所需要的数据,可以用%u,%d或%o,%x格式输入。l可以指定输入数据所占的列数,系统自动按它截取所需数据。l如果在%后有一个“*”附加说明符,表示跳过它指定的列数。l输入数据时不能规定精度。 使用使用scanf函数时

26、应注意的问题函数时应注意的问题 :(1) scanf函数中的“格式控制”后面应当是变量地址,而不应是变量名。 (2) 如果在“格式控制”字符串中除了格式说明以外还有其他字符,则在输入数据时在对应位置应输入与这些字符相同的字符。 (3) 在用“”格式输入字符时,空格字符和“转义字符”都作为有效字符输入 。(4) 在输入数据时,遇以下情况时认为该数据结束。 遇空格,或按“回车”或“跳格”(Tab)键; 按指定的宽度结束,如“”,只取列; 遇非法输入。6。 scanf 函数是缓冲数据输入 把所有输入数据解释成:先存放到缓冲区中,遇到缓冲输入函数调用的时候,按照需求,从缓冲区中取出需要的数据。例:sc

27、anf (%5d%5d%c%c, &a, &b, &c1, &c2);scanf (%d%c%c, &a, &c1, &c2);scanf (%d %c %c, &a, &c1, &c2);l格式控制字符串中不要出现 n ;lscanf中出现的普通空格(包括连续出现的空格),表示该位置至少需要输入一个空格。 4.6 顺序结构程序设计举例顺序结构程序设计举例例4.10 输入三角形的三边长,求三角形面积。假设:三个边长a,b,c能构成三角形。已知面积公式:area=s=(a+b+c)*0.5c)b)(sa)(ss(s开始输入三边长计算s计算面积结束#include#includevoid main()float a,b,c,s,area;scanf(%f,%f,%f,&a,&b,&c);s = 1.0/2*(a+b+c);area = sqrt ( s*(s-a)*(s-b)*(s-c) );printf (a=%7.2f,b=%7.2f,c=%7.2f,s=%7.2fn,a, b, c, s); printf ( area=%7.2fn, area);数学函数库因为要用到其中的sqrt函数运行情况:3,4,6a

温馨提示

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

评论

0/150

提交评论