
谭浩强c语言第四章简单程序.ppt
46页第四章,最简单的c程序设计,,主要内容,4.1 C语句概述 4.2 赋值语句 4.3 数据输入输出的概念及在c语言中的实现 4.4 字符数据的输入输出 4.5 格式输入与输出 4.6 顺序结构程序设计举例,4.1 C语句概述,,4.1 C语句概述,一个c程序可以有若干个源程序文件组成 一个源文件可以有若干个函数和预处理命令以及全局变量声明部分组成 一个函数有函数首部和函数体组成 函数体由数据声明和执行语句组成 C语句分为,4.1 C语句概述,(一)控制语句 完成一定的控制功能 1 if() ~else 条件语句 6 break 间断语句 2 for()~ 循环语句 7 switch() 开关语句 3 while()~循环语句 8 goto 转向语句 4 do ~while();循环语句 9 return 返回语句 5 continue 继续语句,4.1 C语句概述,4.1 C语句概述,4.1 C语句概述,4.1 C语句概述,4.2 赋值语句,赋值语句是由赋值表达式加上一个分号构成 例:a=100 赋值表达式 a=100; 赋值语句 条件中不能含有赋值符号,但是赋值表达式 可以包含于条件表达式中 例:if(a=b;) t=a; 错误 if((a=b)0) t=a; 正确,4.2 赋值语句,1:C语言中的赋值号“=”是一个运算符,在其他大多数语言中赋值号不是运算。
2:其他大多数高级语言没有“赋值表达式”这一概念问题:c语言中的赋值语句于其他高级语言的赋值语句有什么不同点?,4.3 数据输入输出的概念及在C 语言中的实现,(一)所谓输入输出是以计算机主机为主体而言的 输出:从计算机向外部输出设备(显示器,打印机) 输出数据 输入:从输入设备(键盘,鼠标,扫描仪)向计算机 输入数据二)C语言本身不提供输入输出语句,输入和输出操作是由C函数库中的函数来实现的 例如: 字符输入函数: getchar 字符输出函数:putchar 格式输入函数: scanf 格式输出函数: printf 字符串输入函数:gets 字符串输出函数:puts,4.3 数据输入输出的概念及在C 语言中的实现,(三)在使用系统库函数时,要用预编译命令“#include”将有关的“头文件”包括到用户源文件中 例如:在调用标准输入输出库函数时,文件开头应该有: #include “stdio.h” 或: #include ,头文件,4.3 数据输入输出的概念及在C 语言中的实现,4.4 字符数据的输入输出,(一)字符输出函数 一般形式:putchar(c) 函数作用:向终端输出一个字符,字符型变量整型变量,4.4 字符数据的输入输出,例4.1 输出单个字符。
#include 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,4.4 字符数据的输入输出,(二)字符输入函数 一般形式:getchar() 函数作用:从终端(或系统隐含指定的输入设备)输入一个字符 函数值: 从输入设备得到的字符4.4 字符数据的输入输出,例4.2 输入单个字符 #include void main() { char c; c=getchar(); putchar(c); putchar(‘\n’); },4.5 格式输入与输出,(一)格式输出函数 函数作用:向终端(或系统隐含指定的输出设备)输出若干个任意类型的数据 一般格式:printf( 格式控制,输出表列),%d:以带符号的十进制形式输出整数 %o:以八进制无符号形式输出整数 %x:以十六进制无符号形式输出整数 To be continued……,4.5 格式输入与输出,%u:以无符号十进制形式输出整数 %c:以字符形式输出,只输出一个字符 %s:输出字符串 %f:以小数形式输出单,双精度数,隐含输出六位小数 %e:以指数形式输出实数 %g:选用%f或%e格式中输出宽度较短的一种格式,不输 出无意义的0,4.5 格式输入与输出,几种常见的格式符的修饰符:,l:用于长整型整数,可加在格式符d,o,x,u前面 m(代表一个正整数):数据最小宽度 n(代表一个正整数):对实数,表示输出n位小数; 对字符串,表示截取的字符个数 —:输出的数字或字符在域内向左靠,4.5 格式输入与输出,d格式符。
用来输出十进制整数 几种用法: ① %d:按十进制整型数据的实际长度输出 ② %md:m为指定的输出字段的宽度如果数据的位数小于m, 则左端补以空格,若大于m,则按实际位数输出 例: printf(″%4d,%4d″,a,b); 若a=123,d=12345,则输出结果为 123,12345 ③ %ld:输出长整型数据 例: long a=135790;/* 定义a为长整型变量*/ printf(″%ld″,a);,4.5 格式输入与输出,(2) o格式符以八进制整数形式输出 输出的数值不带符号,符号位也一起作为八进制数的一部分输出 例:int a=-1; printf(“%d,%o“,a,a); -1在内存单元中的存放形式(以补码形式存放)如下: 1111111111111111 输出为: -1,177777 不会输出带负号的八进制整数对长整数(long型)可以 用“%lo”格式输出还可以指定字段宽度 例:printf(“%8o“,a); 输出为: 177777 (数字前有2个空格),4.5 格式输入与输出,(3)x格式符以十六进制数形式输出整数同样不会出 现负的十六进制数。
例: int a=-1; printf(″%x,%o,%d″,a,a,a); 输出结果为: ffff,177777,-1 可以用“%lx”输出长整型数,也可以指定输出字段的宽度 例: “%12x”,4.5 格式输入与输出,(4)u格式符,用来输出unsigned型数据 一个有符号整数(int型)也可以用%u格式输出; 一个unsigned型数据也可以用%d格式输出; unsigned型数据也可用%o或%x格式输出 (5)c格式符,用来输出一个字符 如:char d=′a′; printf(″%c″,d); 输出字符′a′. 一个整数,只要它的值在0~255范围内,可以用 “%c”使之按字符形式输出,在输出前,系统会将该整数 作为ASCII码转换成相应的字符;一个字符数据也可以用 整数形式输出4.5 格式输入与输出,例4.3 无符号数据的输出 #include void main() { unsigned int a=65535;int b=-2; printf(“a=%d,%o,%x,%u\n”,a,a,a,a); printf(“b=%d,%o,%x,%u\n”,b,b,b,b); },运行结果: a=-1,177777,ffff,65535 b=-2,177776,fffe,65534,4.5 格式输入与输出,例4.4 字符数据的输出。
#include void main() { char c=‘a’; int i=97; printf(“%c,%d\n”,c,c); printf(“%c,%d\n”,i,i); },运行结果: a,97 a,97,4.5 格式输入与输出,(6)s格式符 输出字符串. ① %s例如: printf(″%s″,″CHINA″) 输出字符串“CHINA”(不包括双引号) ② %ms,输出的字符串占m列,若串长大于m,则全部输出, 若串长 小于m,则左补空格 ③ %-ms,若串长小于m,字符串向左靠,右补空格 ④ %m. ns,输出占m列,只取字符串中左端n个字符, 输出在m列的 右侧,左补空格 ⑤ %-m.ns,n个字符输出在m列的左侧,右补空格, 若n〉m,m自 动取n值4.5 格式输入与输出,例4.5字符串的输出 #include void main() { printf(“%3s,%7.2s,%.4s,%-5.3s\n”, “CHINA”, “CHINA”, “CHINA”, “CHINA”); },4.5 格式输入与输出,(7)f格式符用来以小数形式输出实数(包括单双精度) 有以下几种用法: ① %f。
不指定字段宽度,由系统自动指定字段宽度,使整数 部分全部输出,并输出6位小数应当注意,在输出的数字中 并非全部数字都是有效数字单精度实数的有效位数一般为7位 ②%m.nf指定输出的数据共占m列,其中有n位小数如果 数值长度小于m,则左端补空格 ③%-m.nf与%m.nf基本相同,只是使输出的数值向左端 靠,右端补空格4.5 格式输入与输出,例4.6 输出实数时的有效位数 #include void main() { float x,y; x=111111.111;y=222222.222; printf(″%f″,x+y); },运行结果: 333333.328125,4.5 格式输入与输出,例4.7输出双精度数时的有效位数 #include void main() {double x,y; x=1111111111111.111111111; y=2222222222222.222222222; printf(“%f”,x+y); },运行结果: 3333333333333.333010,4.5 格式输入与输出,例4.8 输出实数时指定小数位数 #include void main() { float f=123.456; printf(“%f%10f%10.2f%.2f%-10.2f\n”,f,f,f,f,f); },运行结果: 123.455994 123.455994 123.46 123.46 123.46,4.5 格式输入与输出,(8)e格式符,以指数形式输出实数。
可用以下形式: ① %e不指定输出数据所占的宽度和数字部分的小数位数. 例: printf(″%e″,123.456); 输出: 1.234560 e+002 6列 5列 所输出的实数共占13列宽度注:不同系统的规定略有不同),4.5 格式输入与输出,② %m.ne和%-m.ne m、n和“-”字符的含义与前相同 此处n指拟输出的数据的小数部分(又称尾数)的小数位数 若f=123.456,则: printf(“%e %10e %10.2e %.2e %-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列,说明: 未指定n,自动使n=6. 超过给定的10列,乃突破10列的限制,按实际长度输出 第3个数据共占10列,小数部分占2列 只指定n=2,未指定m,自动使m等于数据应占的长度 第5个数据应占10列,数值只有9列,由于是“%-10.2e”, 数值向左靠,右补一个空格 (注:有的C系统的输出格式与此略有不同),4.5 格式输入与输出,(9)g格式符,用来输出实数. 它根据数值的大小,自动选f格式或e格式(选择输出时 占宽度较小的一种),且不输出无意义的零。
例:若f=123.468,则 printf(″%f %e %e″,f,f,f); 输出如下: 123.468000 1.234680e+002 123.468 10列。






![河南新冠肺炎文件-豫建科[2020]63号+豫建科〔2019〕282号](http://img.jinchutou.com/static_www/Images/s.gif)





