C语言程序设计(数据的输出和输入)
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
2.1数据的输出和输入
scanf()和printf()是标准输入输出函数,是程序输入输出必不可少的,在头文件stdio.h中声明了这两个函数。
2.1.1格式输出函数printf()
1.printf()函数一般格式:
printf(格式控制,输出表列);
printf()函数的功能是将后面的参数按照指定的格式进行输出,可以输出任意类型
的多个数据。
(1)格式控制是由双引号括起来的字符串,它包含三种信息:
·格式说明:由“%”和格式字符组成,如%d,%f等。
它的作用是将输出的数据按照指定的格式输出。
·普通字符:需要原样输出的字符。
·转义字符:用于控制输出。
(2)输出表列是一些要输出的数据。
例如:
普通字符输出表列
printf("sum=%d",sum);
格式说明
语句中用了d格式符,用来输出十进制整数。
2.常用格式符
(1)%d格式符
%d用来输出10进制整数,正数输出不带符号,负数输出带负号。
d前面还可以加一
个整数,表示数据输出的最小宽度。
例如:
/*格式说明%md,%ld,%u及转义字符\n等的用法*/
#include<stdio.h>
int main()
{
int a=-1,b=25,c=125;
long x=-356142;
printf("%d,%5d\n",a,b);
printf("%5d,%2d\n",c,c);
printf("%ld,%u\n",x,x);
return0;
}
输出结果为:
-1,25
125,125
-356142,4294611154
%5d表示输出数据的最小宽度为5,不够5位左端用空格补齐。
对于变量c,%2d规定输出数据最小宽度为2,实际数据为3位,则突破限制,按照实际位数输出。
对长整型数据x,在d前要加字母l,即要用%ld输出,如果用%u,则会引起把有符号数据的符号位处理成数值,从而把负数处理成正数。
上例中最后一个输出就是将-356142的符号位1(代表负数),当成数值1,按位权展开求和,得到4294611154的输出结果。
(2)%f格式符
%f用来以小数形式输出单、双精度的实数。
可以象整型数据一样指定宽度,也可以指定小数位数。
例如:
/*格式说明%m.nf的用法*/
#include<stdio.h>
int main()
{
float x=123.456;
double y=216.5273528;
printf("%f,%7.2f\n",x,x);
printf("%f,%7.2f\n",y,y);
return0;
}
输出结果为:
123.456001,123.46
216.527353,216.53
以%f格式输出时,默认的小数位数为6位。
由于单精度小数的有效数字位数是7位,超过7位就不是准确数字了,所以以%f格式输出x时结果为123.456001,双精度小数的有效数字为15-16位,所以以%f格式输出y时结果为216.527353。
%7.2f表示输出数据最小宽度为7,小数点以后保留2位,所以以%7.2f格式输出x时结果为123.46,输出y 时结果为216.53,左端补一个空格。
(3)%c格式符
%c格式符用来输出一个字符。
如果有一个整数,值在0~255之间,也可以用字符方式输出。
例如:
/*格式说明%c、%md的用法*/
#include<stdio.h>
int main()
{
char ch=´a´;int m=65;
printf("%c,%3c,%d\n",ch,ch,ch);
printf("“%c,%d,%4d\n",m,m,m);
return0;
}
输出结果为:
a,a,97
A,65,65
以%c格式输出的是字符型数据的字符形式,以%d输出的是字符的ASCII码。
对于整数m,用%c输出的是该整数对应的字符形式。
除了上面介绍的格式符以外,还有一些其它格式符。
printf()函数的格式字符含义见表2-4所示。
表2-4printf()函数的格式符
格式字符含义
d十进制形式输出带符号整数(正数输出不带符号)
o八进制形式输出无符号整数(不输出前导0)
x十六进制形式输出无符号整数(不输出前导0x)
U十进制形式输出无符号整数
C输出一个字符
S输出一个字符串
F小数形式输出单、双精度实数(隐含输出6位小数)
E指数形式输出单、双精度实数(隐含输出6位小数)
G当指数小于-4或大于给定的精度时用%e格式,否则用%f格式。
表2-5附加格式说明符
字符含义
字母l用于长整型,可加在格式符d,o,x,u之前
m(整数)数据最小宽度
.n(整数)对实数,表示输出n位小数;对字符串,表示截取的字符个数
—输出的数字或字符在域内向左靠
2.1.2格式输入函数scanf()
1.scanf()函数一般格式:
scanf(格式控制,地址表列);
scanf()函数的功能是按照指定的格式输入数据,可以输入任意类型的多个数据。
格式控制与printf()函数含义相同,它由若干个格式说明构成,其作用是控制转换输入数据的类型。
地址表列由若干个地址构成,它们可以是变量的地址,也可以是字符串的首地址。
2.当输入一串数据时,系统如何区分每个数据呢?
(1)根据格式字符的含义分隔字符。
sacnf("%d%c%f",&a,&b,&c);
若输入数据:
120a45.6
则a=120,b='a',c=45.6
(2)系统按格式串指定的长度截取所需的数据。
scanf("%3d%2d",&a,&b);
输入数据
12345
则a=123,b=45
(3)用隐含的分隔符。
在输入数据中用空格、换行符或TAB分隔数据。
scanf("%d%d%d",&a,&b,&c);
输入数据
345
或输入
3
45
则a=3,b=4,c=5
(4)使用显示分隔符。
在格式说明符中还可以有其它字符,在输入字符时应输入与这些字符相同的字符。
scanf("%d,%d,%d",&a,&b,&c);
输入数据
3,4,5
则a=3,b=4,c=5
如果是
scanf("%d:%d:%d",&a,&b,&c);
输入时,两个数据要用“:”分隔
3:4:5
(5)%后的“*”附加说明符,用来表示跳过它相应的数据。
scanf("%d,%*d,%d",&a,&b);
如果输入
3,4,5
则a=3,b=5,第二个数据跳过不赋给任何变量。
scanf()函数的格式字符含义见表2-6所示。
表2-6scanf()函数的格式符
格式字符含义
d用来输入十进制整数
o用来输入八进制整数
x用来输入十六进制整数
c输入一个字符
s输入一个字符串,以‘\0’为结束标志
f用来输入实数,可以用小数形式或指数形式
e与f作用相同
表2-7附加格式说明符
字符含义
字母l用于输入长整型或double型,可加在格式符d,o,x,e,f 之前
字母h用于输入短整型,可加在格式符d,o,x之前
m(整数)指定输入数据所占宽度
*跳过本项输入,读入后不送给相应变量。