




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、一、第四章p56-58页的习题4.14.3。4-1(1)分析并写出下列程序运行结果#include <stdio.h>main()char c1='a',c2='b',c3='c' /*定义三个字符*/printf("a%cb%cc%cn",c1,c2,c3); /*格式化输出三个字符*/ 结果:(2)#include <stdio.h>main()int a=12,b=15;printf("a=%d%,b=%d%n",a,b); /*格式化输出a=12%,b=15%*/结果:(3)
2、假设程序输入123456#include <stdio.h>main()int a,b;scanf("%2d%*2s%2d",&a,&b); /*对输入的数取前两位赋给a,跳过长度为2 的字符串,再取两位数赋给b*/printf("%d,%dn",a,b);结果:4-2分析下面程序,请指出错误原因和程序错在哪里,并改正错误改正后:#include <stdio.h>main()long a,b;float x,y;scanf("%ld,%ld",&a,&b);getchar();
3、scanf("%5f,%5f",&x,&y);printf("a=%ld,b=%ldn",a,b);printf("x=%f,y=%fn",x,y);错误分析: 1、定义long 型,输入时要写成 %ld ,输入时不能加入 n ,取址符号 & 丢掉,scanf 函数中不 .n,规定精度 2、输出a,b对应为long型,输出格式符为 %ld ,x,y对应为float型,输出格式为%f,%f 3、在两个scanf() 函数中,输入4个数时,会在两个整数和两个浮点型数之间加入逗号,但加入逗号后,第二条scanf()
4、语句会认为逗号也为有效输入项,后面的浮点型数就不会被读入,所以要加入getchar() 函数将逗号吸收掉。4-3、填空题(1)要使下面程序在屏幕上显示1,2,34,则从键盘输入的数据格式应为 1234#include <stdio.h>main()char a,b;int c;scanf("%c%c%d",&a,&b,&c);printf("%c,%c,%dn",a,b,c);结果:(2)在与上面程序的键盘输入相同的情况下,若将程序中的第7条语句修改为Printf(“%-2c%-2c%dn”,a,b,c);则屏幕输出为
5、 1 2 34(3)要使上面程序的键盘输入数据格式为1,2,34,输出语句在屏幕上显示的结果也为1,2,34,则应将程序中的第六条语句修改为 scanf("%c%*c%c%*c%d",&a,&b,&c) (4)在(3)的程序基础上,程序仍然输入1,2,34,若将程序中的第7条语句修改为 Pirntf(“%c,%c,%dn”,a,b,c);则程序的屏幕输出为 1,2,34(5) 要使上面程序的键盘输入无论用哪种格式输入数据,程序在屏幕上的输出结果都为1,2,34,则将程序中的第6条语句修改为 scanf("%c%*c%c%*c%d"
6、,&a,&b,&c);第1种输入方式:1,2,34 (以逗号作为分隔符)第2种输入方式:1 2 34 (以逗号作为分隔符)第3种输入方式:1234 (以逗号作为分隔符)第4种输入方式:1234 (以回车作为分隔符)二、收集资料,总结printf和scanf函数的用法。一、print格式化输出函数 1、print(“要输出的字符序列”)注意:“要输出的字符序列”必须用英文的双引号括起来,其作用是在屏幕上原样输出“要输出的字符序列”。 例如:printf(“I love china!”);屏幕结果:I love china!2、printf(“输出格式控制符”,输出列表项)
7、注意:“输出格式控制符”必须用英文的双引号括起来,其作用是按照输出格式来输出后面的输出列表项的值。Printf(“%d,%d”,x,y);的作用是:以%d的格式输出变量x,y的值,中间以逗号分隔。 “输出格式控制符”可以是:(1) 格式符:即由%和格式字符组成,如:%d,%f等(2) 普通字符:如printf(“a=%d,b=%dn”,a,b);中的“a=”、“b=”都是普通字符,普通字符原样输出。(3) 转义字符:如printf(“a=%d,b=%dn”,a,b);中的“n”。其含义是“换行”。C语言中常使用的格式字符共用9种。格式符字 说 明d , i输出带符号位的十进制整数(整数前无符号
8、)O以八进制无符号形式输出整数(无前导o)X或x 以十六进制无符号形式输出整数(无前导ox),用x则输出的af是小写的形式,用X则输出的af是大写的形式U以十进制无符号型输出整数 C输出一个字符 S输出字符串的字符,遇到“0”时结束输出,或者输出由精度指定的字符数F以小数形式输出单精度或双精度数,隐含输出六位小数,当指定精度为0时,小数部分(包含小数点)都不输出E 或 E以标准形式输出单双精度数,当用E时,指数部分的e用E表示,小数位数保留6位G或 g由系统决定采用%f,%e,%E的格式,以使输出宽度最小,当用G时,指数部分e用E表示 %输出百分号%在格式说明中,在%和上述格式字符之间还可以插
9、入修饰符,如下表:修饰符 说 明L或 l输出长整形,放在d,o,x,u之前;输出double型,放在f、e之前 h输出短整型,放在d,o,x,u之前 m输出数据宽度 n对于实数,表示输出n位小数,对于字符串,表示截取字符个数 -输出的数据在域内左对齐Printf()函数常用的格式符如下:(1) d格式符用来输出十进制整数%d:以整数的实际位数输出%+d:以整数的十进制实际位数输出,输出的正整数前带“+”%md:输出的整数有m列并右对齐,当m大于整数的宽度时,多余的位数用空格填补,当m小于整数的宽度时,则按实际宽度输出%-md:输出的整数有m列并左对齐,当m大于整数的宽度时,多余的位数用空格填补
10、,当m小于整数的宽度时,则按实际宽度输出 例如:printf(“%8dn,%-8dn”,2009,2009); 结果为: 2009 2009%ld或%Ld:按实际位输出长整形数据%hd:按实际位数输出短整型数据%mld或%mLd:输出的长整型数据有m列并右对齐,当m大于整数的宽度时,多余的位数用空格填补,当m小于整数的宽度时,则按实际宽度输出%-mld或%-mLd:输出的长整型数据有m列并左对齐,当m大于整数的宽度时,多余的位数用空格填补,当m小于整数的宽度时,则按实际宽度输出例如:long x=123456;printf("%8ldn%-8ldn",x,x);结果: 12
11、3456 123456%0md: 输出的整数有m列并右对齐,当m大于整数的宽度时,多余的位数用0填补,当m小于整数的宽度时,则按实际宽度输出注意:没有%-0md(2)o,x,u的格式符用法与d相同,只是o,x,u不考虑符号位 例如: 结果: (3)c格式符用来输入一个字符。用法:%c:输出一个字符%mc:输出的字符占m列并右对齐,多余的空位用空格填补%-mc: 输出的字符占m列并左对齐,多余的空位用空格填补 例如:printf(“%-4cn%4cn”,A,A); 结果:A A(4)s格式符用来输出一个字符串。用法: %s:以字符串的实际长度输出一个字符串 %ms: 输出的字符串占m列并右对齐,
12、当m大于字符串的宽度时,多余的位数用空格填补,当m小于字符串的宽度时,则按实际宽度输出 %-ms:输出的字符串占m列并左对齐,当m大于字符串的宽度时,多余的位数用空格填补,当m小于字符串的宽度时,则按实际宽度输出 例如: 结果: %m.ns:在m列的位置上输出一个字符串的前n个字符,并右对齐,m>n时,多余的位数用空格填补;m<n时,输出n位实际长度的字符串。 %-m.ns:在m列的位置上输出一个字符串的前n个字符,并左对齐,m>n时,多余的位数用空格填补;m<n时,输出n位实际长度的字符串。例如: 结果: (5)f格式符以小数形式输出单双精度实数 %f:输出单精度实数
13、,整数部分全部输出,小数部分保留6位,在有效范围内的小数部分要进行四舍五入。 %lf或%Lf:输出双精度实数,整数部分全部输出,小数部分保留6位,在有效范围内的小数部分要进行四舍五入。 例如: 结果: %m.nf:在m列的位置上输出一个实数保留n位小数并右对齐,系统自动对在有效数据范围内的小数部分进行四舍五入。当m大于实际宽度时,则多余位用空格填补,当M小于实际宽度时,实数的整数部分按实际宽度输出。 %-m.nf: 在m列的位置上输出一个实数保留n位小数并左对齐,系统自动对在有效数据范围内的小数部分进行四舍五入。当m大于实际宽度时,则多余位用空格填补,当M小于实际宽度时,实数的整数部分按实际宽
14、度输出,且结果左对齐。 例如: 结果: %.nf:实数的整数部分按实际输出,小数部分保留n位,自动对在有效范围内的小数进行四舍五入保存,结果左对齐。(6)e格式符用来以指数形式输出一个实数,用法同f格式符。 例如:printf(“%e”,12.122344); 结果:1.212234e+001(7)g格式符用来输出实数,系统根据实数的大小,自动选择f格式符或e格式符输出,输出时选择占宽度较小的一种格式输出,且不输出无意义的0总结: 1、数据类型应与格式说明符匹配,否则会出错。 2、int型数据可以用%u格式输出,一个unsigned型数据可用%d,%o,%x格式输出 3、除了X,E,G,L可以
15、大写以外,其他格式必须小写 4、如果需要输出“%”,应在格式符内连续使用两个“%”,如:Printf(“%5.2f%”,3.0/100); 结果:33.33%二、scanf()输入函数 格式输入函数scanf()用于从键盘输入数据,该输入数据按指定的输入格式赋给相应的输入项。 其输入格式为: Scanf(“输入格式控制符”,输入项地址列表);注意:“输入格式控制符”必须用英文的双引号括起来,他的作用是按照输入格式从键盘从键盘键入若干类型的数据给后面的输入项。例如: int a,b;Scanf(“a=%d,b=%d”,&a,&b); 运行时从键盘输入a=3,b=5 按enter
16、键,则变量a和b的值分别是3和5。“输入格式控制符”可以是:(1)格式符:由%和格式字符构成,如%d 和%f等(2)普通字符:如printf(“a=%d,b=%dn”,a,b);中的“a=”,“,”、“b=”都是普通字符,输入时要按原样输入。下表是scanf()格式说明格式字符 说 明d 和 i输入带符号的十进制整数O输入不带符号位的八进制整数X 和x输入不带符号位的十六进制整数,大小写形式相同 u输入不带符号位的十进制整数c输入单个字符s输入字符串f输入实数,以小数形式或指数形式E e g G与f作用相同,e与f,g可以相互替换,大小写形式相同 在格式说明中,在%和上述格式字符之间还可以插入下表的修饰符格式字符 说 明L 或l输入长整形,放在d,o,x,u的前面;输入double型,放在f,e之前h 输入短整型,放在d,o,x,u之前m用来指定输入数据的宽度*表示输入项在读入后不赋给相应的变量输入scanf()函数要注意以下几点:(1)地址表列要用地址运算符“&”取变量的地址或用指针变量(2)“输入格式控制符”中的普通字符一定要按照
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 共同股权投资合同范本
- 关于续签监控合同范本
- 凉皮店用工合同范例
- 事业单位劳务合同范本3篇
- 公司考核合同范本
- 下班无偿保洁合同范本
- 入股销售合同范本
- 北京贷款合同范本
- 农业设备运输合同范例
- 公司签承揽合同范本
- 《魔方知识普及》课件
- 东芝授权委托书标准版
- 2023施工项目部标准化工作手册
- 中小学幼儿园中班下册点点回家公开课教案教学设计课件案例测试练习卷题
- SG-400140型火电厂锅炉中硫烟煤烟气喷雾干燥法脱硫+袋式除尘系统设计
- 中型轿车的盘式制动器的设计
- 低血糖急救护理课件
- 学做小小按摩师(课件)全国通用三年级上册综合实践活动
- 阴道镜检查临床医学知识及操作方法讲解培训PPT
- “教学评一体化”指导的语文教学设计以统编版语文四年级上册《蟋蟀的住宅》为例
- AI09人工智能-多智能体
评论
0/150
提交评论