4
C语言本身没有提供输人输出语句,所有的数据输入输出功能都是由系统提供的库函数完成的,程序中用到的标准输人输出库函数主要有printf()、scanfO)等。使用标准输入输出库函数时要用到“stdio. h”文件,因此在源文件开头需要用预处理命令# include
1.printf()函数
prinf()函数是系统提供的用于在标准输出设备(屏幕)输出数据的库函数,其一般调用格式为:
printf("格式控制字符串",输出项表列)
格式控制字符串用双引号括起来,表示输出的格式;而输出项表列则是要输出的数据,这些数据可以是常量、变量或表达式。
格式控制字符串中包含两种信息,格式控制说明和普通字符。
(1)格式控制说明:按指定的格式输出数据,其格式为以%开头的格式控制字符,不同类型的数据采用不同的格式控制字符,以说明输出数据的类型、形式、长度、小数位数等。例如,int型数据采用%d, float型和double型数据都采用%f。
(2)普通字符:在输出数据时,需要原样输出字符。
按指定格式输出整形数据示例。
#includeint main() { int a = 1, b = 2, c = 3; printf("a=%d,b=%d,c=%dn", a, b, c); return 0; }
使用printf()函数进行数据输出时需注意:
(1)格式字符与输出项的类型要一一对应,不同类型的数据所使用的格式字符不同。全(2)一般情况下,格式字符与输出项的个数应相同。如果格式字符的个数多于输出项的个数,则多余的格式将输出不确定的值;如果格式字符的个数少于输出项的个数,则多余的输出项将不能输出。
(3)printf()函数中可以没有输出项,此时printf()函数只用来输出一个字符串;也可以有多个输出项,多个输出项之间使用逗号进行分隔。若输出项是表达式时,printf()函数将按从右到左的顺序计算出其值后输出。
(4)若要在printf()函数中输出字符“%”,则应在格式控制字符串中使用连续两个“%”。2. scanf()函数
scanf()函数是系统提供的用于由标准输人设备(键盘)输人数据的库函数,使用该函数时,由键盘输人数据的值。其一般调用格式为:
scanf("格式控制字符串",输入项表列)
格式控制字符串用双引号括起来,表示输人的格式;而输人项表列指出各变量的地址(变量名前加&)。
格式控制宇符串中包含两种信息,格式控制说明和普通字符。
(1)格式控制说明:按指定的格式输人数据,其格式为以%开头的格式控制字符,不同类型的数据采用不同的格式控制字符。例如,int型数据采用%d, float型数据采用%f.而double型数据采用%1f(%lf,其中的1是long的首字母,不是数字1)。
(2)普通字符:在输入数据时,需要原样输人的字符。
注意scanf()函数的输人参数必须和格式控制字符串中的格式控制说明相对应,并且它们的类型、个数和位置都要-对应。 若程序中有多个scanf 函数时,程序会等待用户输入并依次赋给相应变量。
例如,语句“scanf("%d", &.x);”中的格式字符串“%d”指明了要输人数据的类型为十进制整型,输人项“&x”表明从键盘输人的数据将赋值给整型变量X。
使用scanf()函数进行数据输人时需注意:
(1)格式字符与输人项的类型、个数要一一对 应;输入项必须是地址,不能是变量名。(2)格式字符可以指定输人数据所占的列数,系统会截取相应列数的数据。
(2)格式字符可以指定输。人数据所占的列数,系统会截取相应列数的数据。
(3)在输人数据时遇到以下情况则认为数据输人结束:空格、Tab键、回车键非法输人、指定宽度。用户也可以自己指定其他字符作为输入间隔。
3.3.2 整型数据的输入和输出
在C语言中,对于整型数据的输人输出所使用的格式控制字符如下表所示
printf() 、scanf()函数中的格式字符(整型数据)
| 格式字符 | 含义 |
| d | 以十进制形式输入/输出带符号整数 |
| o | 以八进制形式输入/输出无符号整数 |
| x,X | 以十六进制形式输入/输出无符号整数 |
| u | 以十进制形式输入/输出无符号整数 |
在格式字符串的“%”和格式字符之间还可以有一些修饰符,如下表所示
printf()函数中的格式修饰符
| 格式字符 | 含义 |
| 1 | 用于输出长整型 |
| - | 输出结果左对齐,右边补空格 |
| + | 输出符号(正号或负号) |
| # | 对d、u格式字符无影响;对o格式字符,在输出时加前缀0;对x格式字符,在输出时加前缀0x |
| m | 指定数据的输出宽度。当数据的实际位数大于m时,若输出宽度前有“-”则左对齐右补空格,否则右对齐左补空格 |
scanf()函数中的格式修饰符
| 格式字符 | 含义 |
| 1 | 用于输入长整型 |
| m | 指定输入数据所占的宽度 |
| * | 表示本输入项不会赋值给相应的变量 |
整型数据的输出示例:
#includeint main() { int a = 123; long int b = 32770; printf("a=%d,b=%ldn", a, b); printf("a=%o,b=%lon", a, b); printf("a=%#x,b=%#lxn", a, b); printf("a=%d,b=%ldn", a); printf("a+b=%ldn", a + b, b); printf("输出结束!n"); return 0; }
说明:
(1)第4行的输出结果表明,当格式字符的个数多于输出项时,多余格式字符的位置将会输出一个不确定的值。
(2)第5行的输出结果表明,当格式字符的个数少于输出项时,多余的输出项不会输出。
整型数据的输入示例:
#includeint main() { int a, b; long int c; scanf_s("%d%d%ld", &a, &b, &c); printf("a=%d,b=%d,c=%ldn", a, b, c); return 0; }
(1)输入12空格23空格34结果为:
(2)输入12,23空格34结果为
这是由于在输入“12,23空格34↙ ”时,由于存在非数字字符“,”,scanf()函数在遇到非法输入时认为数据输入结束,因此将12赋值给变量a,而后面的数据将会舍弃,变量b和c没有正确赋值,因此b和c的值是不可预知的。
(3)若将语句1改为“scanf("%d, %d, %1d" ,&a, &.b, &c);”,程序运行时输入:
12口23空格34 ↙
则输出结果为:
这是由于在scanf()函数中的格式控制字符串中含有普通字符“,”,普通字符也要原样输入,即输入的数据需使用“,”作为间隔,但是实际输入的数据中没有“,”,因此编译系统只将12赋值给变量a,后面的两个数据23和34将会被舍弃,不会赋值给变量b和c。
此时正确的输人形式应为:
12,23,34↙
数据输入完后,系统会从“,”的位置进行数据分隔,使a=12,b=23,c=34。
(4)若将语句1改为“scanf("a= %d,b= %d,c= %1d",&a,&b,&c);",则scanf()函数的格式控制字符串中的普通字符串“a="、“b=”、“c="以及“,”都要原样输入。
此时正确的输入形式为:
a=12,b=23,c= 34
带有修饰符的整型数据的输入输出示例:
#includeint main() { int a, b, c, d; scanf_s("%2d%3d%*d,%d%d", &a, &b, &c, &d); printf("a=%d,b=%d,c=%d,d=%dn", a, b, c, d); printf("a=%4d,b=%-4d,c=%-4d,d=%4dn", a, b, c, d); printf("a=%+4d,b=%+4d,c=%+4d,d=%+4dn", a, b, c, d); return 0; }
若运行时输入:123456789,123空格456↙
分析:
(1)根据程序中scanf()函数的格式控制字符串"%2d%3d%*d,%d%d",编译系统会从输人的内容中先取2列宽度的数字,使a=12,然后取3列数字,使b=345,接下来跳过后面的数字6789,对于逗号后面的输人内容“123空格456”,编译系统是从空格的位置进行分隔的,将123和456分别赋值给变量c和d,因此c= 123,d= 456。
(2)程序中的printf()函数在输出变量a、b、c、d的值时指明了输出的宽度,则当变量值的实际宽度大于输出宽度时按实际数据输出,当变量值的宽度小于输出宽度时,若输出宽度前有“一”则左对齐右补空格,否则右对齐左补空格。在“ %”和格式符之间的修饰符“十”,表明要输出数据的符号(正号或负号)。
3.3.3实型数据的输入和输出在C语言中,对于实型数据的输入和输出所使用的格式控制字符如下表所示
说明:
(1)在格式字符串的“%”和格式字符之间也可以有-些修饰符,与表 3.2、3.3相同。printf()函数中的修饰符“#”对于f、e、g格式字符当结果有小数时才给出小数点。
(2)在输出实型数据时,还可以指定输出的精度,即在格式字符串的“%”和格式字符之间加人“m.n”,其中m指明输出的总位数,n指明小数点后的位数,若实际输出位数大于n,则超出的部分四舍五入;若实际输出位数小于n则不足的部分后补0。
(3)使用scanf()丽数输入实型数据时不能指明精度,即使用“%.nf”的格式是错误的。
实型数据的输入输出示例:
#includeint main() { float f; double d; scanf_s("%f%lf", &f, &d); printf("f=%f,d=%fn", f, d); printf("f=%e,d=%en", f, d); printf("f=%4.2f,d=%.3fn", f, d); return 0; }
若在程序运行时输人:
201.36541空格156987.685 102345↙
则第一个数据201. 3654赋值给float 型变量f, 第二个数据56987. 685102345赋值给double型变量d。
语句1处,分别以小数形式输出变量f和d的值并保留6位小数。
语句2处,分别以指数形式输出f和d的值。
语句3处,“%4. 2f"要求保留2位小数且输出宽度是4,此时变量f的实际位数大于4,则保留2位小数后按实际位数输出,“%.3f"要求保留3位小数输出。最后的输出结果为;
3.3.4字符型数据的输入和输出字符型数据的输入输出可以调用函数getchar( )、scanf()和putchar()、printf()。其中getchar()和putchar()函数只能用于单个字符的输入输出,scanf( )和printf() 函数可以用于多个字符的输入输出。
1.使用scanf()函数和printf()函数对字符型数据进行输入输出
使用scanf()函数和printf()函数进行字符型数据的输入输出时,其相应的格式控制字符为“c”,如“printf(" %c%cn",a,b)”,也可以在“%”和“c”之间加修饰符,与图 printf()函数中的格式修饰符和 scanf()函数中的格式修饰符中的相同
字符型数据的输入输出示例:
#includeint main() { char a, b, c; scanf_s("%c%c%c",&a,&b,&c); printf("a=%3c,b=%c,c=%cn", a, b, c); return 0; }
2.使用getchar( )函数和putchar()函数对字符型数据进行输入输出
(1)getchar( )函数。
设ch是字符型变量,函数getchar()的一般调用格式为:
ch= getchar() ;
运行时从键盘输入缓冲区中读取一个字符,并赋值给变量ch。由于函数getchar()只能读入一个字符,若需输入多个字符,就需要多次调用函数,一般采用循环调用的方式。
(2)putchar( )函数。
函数putchar()的-般调用格式 为:
putchar(输出参数);
输出一个字符,输出参数是字符型变量或字符型常量。
由键盘输入一个字符,将其输出到屏幕:
说明:
(1)用getchar()函数得到的字符可以赋给--个字符变量或整型变量,也可以不赋给任何变量,而直接作为putchar()函数的参数。本例可以改写如下:
#includeint main() { putchar(getchar()); return 0; }
(2)可以在Printf函数中输出刚接收的字符。如
#includeint main() { printf("%c", getchar()); return 0; }
3.4数学库函数
C语言处理系统提供了许多事先编好的库函数,供用户在编程序时使用,这些事先编好的函数称为库函数。
常用的数学库函数有:
输出一个球的半径,根据公式
计算并输出球的体积:
#include#include ; #define PI 3.14 int main() { float r, v; printf("输入半径r:"); scanf_s("%f", &r); v = 4.0 / 3 * PI * pow(r, 3); printf("体积为:%.2fn", v); return 0; }
#include#include ; int main() { float a, b, c, x1, x2, p, q; printf("请输入三个系数:"); scanf_s("a=%f,b=%f,c=%f",&a,&b,&c); p = -b / (2 * a); q = sqrt(b * b - 4 * a * c) / (2 * a); x2 = p + q; x2 = p - q; printf("x1=%5.2fnx2=%5.2fn",a,b,c); return 0; }
在输入三个系数为a=3,b=4,c=5时,运行结果为



