《数据输入与输出》PPT课件

上传人:xiao****1972 文档编号:183308414 上传时间:2023-01-30 格式:PPT 页数:47 大小:388.50KB
收藏 版权申诉 举报 下载
《数据输入与输出》PPT课件_第1页
第1页 / 共47页
《数据输入与输出》PPT课件_第2页
第2页 / 共47页
《数据输入与输出》PPT课件_第3页
第3页 / 共47页
资源描述:

《《数据输入与输出》PPT课件》由会员分享,可在线阅读,更多相关《《数据输入与输出》PPT课件(47页珍藏版)》请在装配图网上搜索。

1、C语言程序设计语言程序设计第四章 顺序结构数据的输入和输出顺序程序设计回顾上章:C语言的常用基本符号 C 语言的数据类型 运算符和表达式 数据类型转换 自增,自减运算本章目标:数据的输出 格式输出函数printf()字符输出函数putchar()数据的输入 格式输入函数scanf()字符输入函数getchar()(一).所谓输入输出是以计算机主机为主体而言的输出:从计算机向外部输出设备(显示器,打印机)输出数据输入:从输入设备(键盘,鼠标,扫描仪)向计算机输入数据.(二).C语言本身不提供输入输出语句,输入和输出操作是由C函数库中的函数来实现的例如例如:字符输入函数:getchar 字符输出函

2、数:putchar格式输入函数:scanf 格式输出函数:printf字符串输入函数:gets 字数串输出函数:puts(三).在使用系统库函数时,要用预编译命令“#include”将有关的“头文件”包括到用户源文件中.例如:在调用标准输入输出库函数时,文件开头应该有:#include“”(系统到当前目录寻找要包含的文件,找不到,再按标准方式查找)或:#include (标准方式:系统到存放C库函数头文件的目录中寻找要包含的文件)格式:putchar(c)参数:c为字符常量、变量或表达式功能:把字符c输出到显示器上返值:正常,为显示的代码值;出错,为EOF(-1)5C语言无I/O语句,I/O操

3、作由函数实现4.1 数据输出字符输出函数#include main()int c;char a;c=65;a=B;putchar(c);putchar(n);putchar(a);运行结果:A B例4-1 例4-2 阅读程序#include main()char c1=A,c2=66;int c3=103,c4;c4=c3+1;putchar(c1);putchar(c2);putchar(n);putchar(c3);putchar(c4);运行结果;ABCD格式:printf(“格式控制串”,输出表列)功能:按指定格式向显示器输出数据返值:正常,返回若干个任意类型的数据;出错,返回EOF(

4、-1)格式输出函数v输出表列:需要输出的一系列数据(可以没有,多个时以“,”分隔)v格式控制串:包含两种信息l格式说明:%修饰符格式字符 ,用于指定输出格式l普通字符或转义序列:原样输出1.函数的基本功能2.函数的使用说明(1)格式说明符:由“%”和格式字符组成,如%d,%f等。它的作用是将输出表列的数据转换为指定的格式输出。格式说明符总是由“%”字符开始。(2)普通字符:格式控制字符串中除格式说明符外的其它字 符,其中也包括转义字符,这是一类需要原样输出的字符。(3)“输出表列”是需要输出的一系列数据,可以是表达式。格式控制字符串中格式字符的个数和输出表列的项数相等,顺序从左到右依次对应。(

5、4)格式说明符的类型必须与其对应的输出表列中数据的类型一致。例4-3 阅读程序#include main()int a=3,b;printf(a=%d,b=%dn,a,b=4);其中:a=%d,b=%d 格式控制字符串a,b=4 输出表列%d 格式说明符“a=”“,”“b=”普通字符 运行结果:a=3,b=43.格式说明符一般形式:%-m.nl格式符 其中方括号中内容是可选项。说明:负号表示当实际数据的宽度小于显示宽度时,数据左对齐,数据右方用空格填充。m:表示占用数据的宽度,如果实际数据的宽度大于m,按实际宽度输出。如果实际数据的宽度小于m,数据右对齐,数据左方用空格填充。n:表示指定输出的

6、数据共占m列,其中有n位小数.舍去的部分系统自动四舍五入。如果输出的是字符串,表示取字符串中左端n个字符输出。l:用于长整型或双精度型的数据。(1)整型数据一般形式:%-mL格式符 或%-ml格式符 如果不指定数据宽度和对齐方式,例如%d,系统自动按整型全部输出。说明:1 d格式符(或i格式符),用来输出十进制整数.有以下几种:几种用法:%d:按十进制整型数据的实际长度输出。%md:m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。例:#include main()int a=123,b=12345;printf(%4d,%4d,a,b);%ld:输出

7、长整型数据。例:#include main()long a=135790;/*定义a为长整型变量*/printf(%ld,a);2 o格式符,以8进制数形式输出整数。o格式符是将内存单元中的各位的值(0或1)按八进制形式输出,因此输出的数值不带符号,即将符号也一起作为八进制数的一部分输出.例:int a=-1;printf(%d,%o,a,a);在内存单元中的存放形式(以补码形式存放)如下:输出为:,37777777777不会输出带负号的八进制整数。对长整数(型)可以用“”格式输出。还可以指定字段宽度,例:printf(,);输出为:177777。(数字前有2个空格)(3)格式符格式符。以十六

8、进制数形式输出整数。同样不会出现负的十六进制数。例:#includevoid main()int a=-1;printf(%d,%o,%xn,a,a);输出结果为:可以用“”输出长整型数,也可以指定输出字段的宽度例:“”(4)格式符格式符,用来输出unsigned型数据.一个有符号整数(int 型)也可以用格式输出;一个unsigned 型数据也可以用格式输出。unsigned 型数据也可用或格式输出。例例4-5 4-5 无符号数据的输出。无符号数据的输出。#includevoid main()unsigned int a=65535;int b=-2;printf(a=%d,%o,%x,%u

9、n,a,a,a,a);printf(b=%d,%o,%x,%un,b,b,b,b);(2)实型数据一般形式:%-m.n类型符 实型数据的输出有三种格式:(1)f格式,以小数形式输出实数。(包括单双精度)一般形式:%-m.nf 如果不指定数据宽度和对齐方式,例如%f,系统自动指定,使整数部分全部如数输出,并输出6位小数。有以下几种用法:。不指定字段宽度,由系统自动指定字段宽度,使整数部分全部输出,并输出位小数。应当注意,在输出的数字中并非全部数字都是有效数字。单精度实数的有效位数一般为位。.。指定输出的数据共占列,其中有位小数。如果数值长度小于,则左端补空格。.与.基本相同,只是使输出的数值向左

10、端靠,右端补空格。例4-6 输出实数时的有效位数。输出实数时的有效位数。#include void main()()float,;,;printf(,);,);运行结果:.例4-7输出双精度数时的有效位数。输出双精度数时的有效位数。#include void main()double x,yprintf(%fn,x+y);例例4-8 4-8 输出实数时指定小数位数。输出实数时指定小数位数。#includevoid main()float f=123.456;printf(%fn%10fn%10.2fn%.2fn%-10.2fn,f,f,f,f,f);(2)格式符,以指数形式输出实数。可用以下形

11、式:。不指定输出数据所占的宽度和数字部分的小数位数.例:4-9#includevoid main()printf(%en,123.456);所输出的实数共占列宽度。(注:不同系统的规定略有不同)和-。、和“”字符的含义与前相同。此处指拟输出的数据的小数部分(又称尾数)的小数位数。例4-10#includevoid main()float f=123.456;printf(%en%10en%10.2en%.2en%-10.2en,f,f,f,f,f);输出如下:1.234560e+002 1.234560e+002 1.23e+002 1.23e+002 13列 13列 10列 9列 1.23e

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

13、f(,);输出如下:1.234680e+002 123.468 10列 13列 10列说明:用格式输出占列,用格式输出占列,用格式时,自动从上面两种格式中选择短者(今以格式为短)故占列,并按格式用小数形式输出,最后3个小数位为无意义的,不输出,因此输出,然后右补3个空格。格式用得较少。例4-12 阅读程序。#include main()float x=2.345;double y=2.345;printf(x1=%f,x2=%6.2f,x3=%-6.2f,x4=%.2fn,x,x,x,x);printf(y1=%f,y2=%6.2f,y3=%-6.2f,y4=%.2fn,y,y,y,y);运行

14、结果:(3)字符型数据 字符型数据的输出有二种格式符:(1)c格式符 一般形式:%c功能:用来输出一个字符。一个整数,只要它的值在33126范围内,也可以用字符形式输出,在输出前,将该整数转换成相应的ASCII字符;反之,一个字符数据只要它的ASCII码值在33126范围内也可以用整数形式输出。例4-13 阅读程序#include main()char ch=a;int i=97;printf(%c,%dn,ch,ch);printf(%c,%dn,i,i);运行结果:a,97a,97(2)s 格式符一般形式:%-m.ns功能:用来输出一个字符串。如果不指定字符宽度和对齐方式,例如%s,系统自

15、动指定,使整个字符串全部输出。例4-14 阅读程序main()printf(s1=%5.2s,s2=%-5.2s,s3=%.2s,s4=%3s,s5=%s,abcd,abcd,abcd,abcd,abcd);运行结果:s1=ab,s2=ab,s3=ab,s4=abcd,s5=abcdd,ix,Xoucse,Efg%v格式字符十六进制无符号整数不带符号十进制整数十进制整数指数形式浮点小数单一字符字符串八进制无符号整数小数形式浮点小数e和f中较短一种百分号本身int a=567;printf(“%d”,a);int a=255;printf(“%x”,a);int a=65;printf(“%o”

16、,a);int a=567;printf(“%u”,a);char a=65;printf(“%c”,a);printf(“%s”,“ABC”);float a=567.789;printf(“%e”,a);float a=567.789;printf(“%f”,a);float a=567.789;printf(“%g”,a);printf(“%”);567ff101567AABCe+02%l说明u格式字符要用小写u格式字符与输出项个数应相同,按先后顺序一一对应u输出转换:格式字符与输出项类型不一致,自动按指定格式输出例 main()unsigned int u=65535;printf(u

17、=%dn,u);输出结果:u=65535例 int a=3,b=4;printf(“%d%dn”,a,b);printf(“a=%d,b=%dn”,a,b);例#include main()int a=3,b=4;printf(%d%dn,a,b);printf(a=%d,b=%dn,a,b);输出结果:3 4 a=3,b=411 11 11 11 11 11 11 1165535v附加格式说明符(修饰符).n对实数,指定小数点后位数(四舍五入)对字符串,指定实际输出位数(从左边截取)修饰符功 能m输出数据域宽,数据长度m,左补空格;否则按实际输出输出数据在域内左对齐(缺省右对齐)-指定在有符

18、号数的正数前显示正号(+)+输出数值时指定左面不使用的空位置自动填00在八进制和十六进制数前显示前导0,0 x#在d,o,x,u前,指定输出精度为long型在e,f,g前,指定输出精度为double型l例#include main()int a=1234;float f=123.456;char ch=a;printf(%8d,%2dn,a,a);printf(%f,%8.1f,%.2f,%.2en,f,f,f,f);printf(%3cn,ch);运行 1234,1234结果:123.456001,123.456001,123.5,123.46,1.23e+002 a例#include ma

19、in()static char a=Hello,world!;printf(%sn%15sn%10.5sn%2.5sn%.3sn,a,a,a,a,a);运行结果:Hello,world!Hello,world!Hello Hello Hel 例 例#include main()int a=1234;float f=123.456;static char c=Hello,world!;printf(%8d,%-8dn,a,a);printf(%10.2f,%-10.1fn,f,f);printf(%10.5s,%-10.3sn,c,c);运行结果:1234,1234 Hello,Hel 例 -例

20、#include main()int a=1234;float f=123.456;printf(%08dn,a);printf(%010.2fn,f);printf(%0+8dn,a);printf(%0+10.2fn,f);例 0、+例#include main()int a=123;printf(%o,%#o,%X,%#Xn,a,a,a,a);例#例#include main()long a=65536;printf(%d,%8ldn,a,a);例 l说明:除了X,E,G外,其他各式字符必须用小写。可以在printf函数中的“格式控制”字符串中包含转义字符。一个格式说明必须以“%”开头,

21、以9个格式字符之一为结束,中间可以插入附加格式字符。想输出%,则应该在格式控制字符串中用连续两个%表示格式:getchar()功能:从键盘读一字符返值:正常,返回读取的代码值;出错,返回EOF(-1)4.2 数据输入字符输入函数 例#include main()int c;printf(Enter a character:);c=getchar();printf(%c-hex%xn,c,c);运行结果:Enter a character:AA-hex41格式输入函数格式:scanf(“格式控制串”,地址表列)功能:按指定格式从键盘读入数据,存入地址表指定的 存储单元中,并按回车键结束返值:正常

22、,返回输入数据个数v地址表列:变量的地址,常用取地址运算符&v格式字符:d,i,o,x,u,c,s,f,e例 scanf(“%d”,&a);输入:10 则 a=10例 scanf(“%x”,&a);输入:11 则 a=17v附加格式说明符(修饰符)l修饰符功 能hm*用于d,o,x前,指定输入为short型整数用于d,o,x前,指定输入为long型整数用于e,f前,指定输入为double型实数指定输入数据宽度,遇空格或不可转换字符则结束抑制符,指定输入项读入后不赋给变量例 scanf(“%4d%2d%2d”,&yy,&mm,&dd);输入 19991015 则1999yy,10 mm,15 d

23、d例 scanf(“%3d%*4d%f”,&k,&f);则123k,8765.43f例 scanf(“%2d%*3d%2d”,&a,&b);输入 1234567 则12a,67bl例#includemain()char c1,c2;scanf(%3c%2c,&c1,&c2);printf(%c%c,c1,c2);输入 abcde 则ac1,d c2v输入分隔符的指定l一般以空格、TAB或回车键作为分隔符l其它字符做分隔符:格式串中两个格式符间字符例 scanf(“%d%o%x”,&a,&b,&c);printf(“a=%d,b=%d,c=%dn”,a,b,c);输入 123 123 123 输

24、出 a=123,b=83,c=291例 scanf(“%d:%d:%d”,&h,&m,&s);输入 12:30:45 则12 h,30 m,45 s例 scanf(“%d,%d”,&a,&b)输入 3,4 则3a,4 b例 scanf(“a=%d,b=%d,c=%d”,&a,&b,&c);输入 a=12,b=24,c=36 v说明:l用“%c”格式符时,空格和转义字符作为有效字符输入如 scanf(“%c%c%c”,&c1,&c2,&c3);若输入abc 则ac1,c2,b c3l输入数据时,遇以下情况认为该数据结束:u遇空格、TAB、或回车u遇宽度结束u遇非法输入如 scanf(“%d%c%

25、f”,&a,&b,&c);若输入1234a123o.26 则 1234 a,a b,123 cl输入函数留下的“垃圾”:例#include main()int x;char ch;scanf(%d,&x);ch=getchar();printf(x=%d,ch=%dn,x,ch);执行:123输出:x=123,ch=10例#include main()int x;char ch;scanf(%d,&x);scanf(%c,&ch);printf(x=%d,ch=%dn,x,ch);执行:123输出:x=123,ch=10解决方法:(1)用getchar()清除(2)用函数fflush(stdi

26、n)清除全部剩余内容(3)用格式串中空格或“%*c”来“吃掉”例 int x;char ch;scanf(“%d”,&x);scanf(“%c”,&ch);或 scanf(“%*c%c”,&ch);4.3顺序结构程序设计举例应用举例#include#include 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,are

27、a);例 输入三角形边长,求面积输入:3,4,6 输出:)()()()(21csbsassareacbas文件包含预处理命令变量定义输入数据输出数据例 从键盘输入大写字母,用小写字母输出#include main()char c1,c2;c1=getchar();printf(%c,%dn,c1,c1);c2=c1+32;printf(%c,%dn,c2,c2);输入:A 输出:A,65 a,9704022acbcbxax方程的根,设例求#include#include main()float a,b,c,disc,x1,x2,p,q;scanf(a=%f,b=%f,c=%f,&a,&b,&c

28、);disc=b*b-4*a*c;p=-b/(2*a);q=sqrt(disc)/(2*a);x1=p+q;x2=p-q;printf(nnx1=%5.2fnx2=%5.2fn,x1,x2);输入:a=1,b=3,c=2 输出:aacbbx242例:输入直角三角形的两个直角边的边长,求斜边的长度和三角形的面积。#include math.hmain()float a,b,c,area;printf(Input a,bn);/*输入提示,a,b为两直角边长度*/scanf(%f,%f,&a,&b);/*输入a,b值*/printf(a=%f,b=%fn,a,b);/*输出a,b值*/c=sqrt

29、(a*a+b*b);area=1./2*a*b;printf(c=%-7.2f,c);printf(area=%-7.2fn,area);输入输入:3,43,4 运行结果运行结果:例 根据下面的输出结果,编写程序,要求用scanf函数输入。ch=A,ASCII=65i=1j=2main()char c;int i,j;float x,y;printf(Input c,i,j,x,yn);/*输入提示*/scanf(%c,%d,%d,%f,%f,&c,&i,&j,&x,&y);/*键盘交互输入*/printf(ch=%c,ASCII=%dn,c,c);/*输出c值并换行*/printf(i=%-3dj=%dn,i,j);/*输出i,j值并换行*/printf(x=%-8.2fy=%.2f,x,y);/*输出x,y值*/输入:a,1,2,12.34,56.78 运行结果:ch=A,ASCII=65i=1j=2本章总结:i格式输出函数printf()i字符输出函数putchar()i格式输入函数scanf()i字符输入函数getchar()

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

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!