数据的输入和输出
printf 函数
printf 函数称为格式输出函数,其关键字最末一个字母 f 即为 ” 格式 ”(format)之意。其功能是按用户指定的格式,把指定的数据显示到显示器屏幕上。
printf 函数调用的一般格式。
printf 函数是一个标准库函数,它的函数原型在头文件 ”stdio.h” 中。
printf 函数调用的一般形式为:printf(“格式控制字符串”, 输出表列)。其中格式控制字符串用于指定输出格式。格式控制串可由格式字符串和非格式字符串两种组成。格式字符串是以 % 开头的字符串,在 % 后面跟有各种格式字符,以说明输出数据的类型、形式、长度、小数位数等。
#include <stdio.h>
int main(void)
{
int a=88,b=89;
printf(“%d %d\n”,a,b);
printf(“%d,%d\n”,a,b);
printf(“%c,%c\n”,a,b);
printf(“a=%d,b=%d”,a,b);
return 0;
}
/*
* 通过上面的代码可以看出 printf 的格式,由于格式控制串不同,输出的结果也不相同。
* 第 1 行的输出语句格式控制串中,两格式串 %d 之间加了一个非格式字符(空格),因此输出的 a、b 值之间有一个空格。
* 第 2 行的 printf 语句格式控制串中加入的是非格式字符(逗号),因此输出的 a、b 值之间加了一个逗号。
* 第 3 行的格式串要求按字符型输出 a、b 值。
* 第 4 行中为了提示输出结果又增加了非格式字符串。
*/
printf 函数格式中的格式字符串。
格式字符串的一般形式为:[标志][输出最小宽度][. 精度][长度]类型。
最小宽度:用十进制整数来表示输出的最少位数。
/*
当转换值的字符数(含前缀)小于最小宽度说明时,则使用填充符(空格)将数值填充到最小宽度.
当转换值的字符数(含前缀)大于最小宽度说明时,最小宽度说明失效。
*/
#include<stdio.h>
int main(void)
{
int x=45,y=-45678;
printf(“%9d,%3d”,x,y);//
return 0;
}
精度:精度格式符以 ”.” 开头,后跟十进制整数。
本项的意义是:
1. 如果输出数字,则表示小数的位数;例如.4 表示保留 4 位有效数字
2. 如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。
长度:长度格式符为 h、l 两种,h 表示按短整型量输出,l 表示按长整型量输出。
#include<stdio.h>
int main(void)
{
int x=34,y=-34;
printf(“x=%8d,y=%8d\n”,x,y);// 表明最小宽度为 8, 用空格进行填充
printf(“x=%08d,y=%08d\n”,x,y);// 用 0 而不是用空格进行填充
printf(“x=% 08d,y=% 08d\n”,x,y);// 空格总是产生一个 - 号或者是空格
printf(“x=%-8d,y=%-8d\n”,x,y);//- 号表示的是左对齐
printf(“x=%- 8d,y=%- 8d\n”,x,y);
printf(“x=%-+8d,y=%-+8d\n”,x,y);//+ 总是产生一个 + 或 - 号
printf(“x=%8.4d,y=%8.4d\n”,x,y);// 精度.4 表示是四位有效数字
printf(“x=%-8.4d,y=%-8.4d\n”,x,y);
return 0;
}
/*
输出结果:
x= 34,y= -34
x=00000034,y=-0000034
x= 0000034,y=-0000034
x=34 ,y=-34
x= 34 ,y=-34
x=+34 ,y=-34
x= 0034,y= -0034
x=0034 ,y=-0034
*/
类型
格式字符
意义
d
以十进制形式输出带符号整数(正数不输出符号)
o
以八进制形式输出无符号整数(不输出前缀 0)
x,X
以十六进制形式输出无符号整数(不输出前缀 0x)
u
以十进制形式输出无符号整数
f
以小数形式输出单、双精度实数
e,E
以指数形式输出单、双精度实数
g,G
以 %f 或 %e 中较短的输出宽度输出单、双精度实数
c
输出单个字符
s
输出字符串
#include<stdio.h>
int main(void)
{
int x=31;
float f=0.1;
char a[10]=”abcde”;
printf(“%7.3d\n”,x);
printf(“%7.3x\n”,x);// 进行无符号十六进制的转换
printf(“%7.3o\n”,x);// 进行无符号八进制的转换
printf(“%7.1E\n”,f);
printf(“%7.3f\n”,f);
printf(“%7.3s\n”,a);
return 0;
}
/*
输出结果:
031
01f
037
1.0E-001
0.100
abc
*/
综合实例
#include <stdio.h>
int main(void)
{
int a=15;
long float b=123.1234567;
double c=12345678.1234567;
char d=’p’;
printf(“a=%d\n”, a);
printf(“a(%%d)=%d, a(%%5d)=%5d, a(%%o)=%o, a(%%x)=%x\n\n”,a,a,a,a);// %% 可以输出 %
printf(“a=%f\n”, b);
printf(“b(%%f)=%f, b(%%lf)=%lf, b(%%5.4lf)=%5.4lf, b(%%e)=%e\n\n”,b,b,b,b);
printf(“c=%f\n”, c);
printf(“c(%%lf)=%lf, c(%%f)=%f, c(%%8.4lf)=%8.4lf\n\n”,c,c,c);
printf(“d=%c\n”, d);
printf(“d(%%c)=%c, d(%%8c)=%8c\n”,d,d);
return 0;
}
/*
输出结果:
a=15
a(%d)=15, a(%5d)= 15, a(%o)=17, a(%x)=f
a=123.123457
b(%f)=123.123457, b(%lf)=123.123457, b(%5.4lf)=123.1235, b(%e)=1.231235e+002
c=12345678.123457
c(%lf)=12345678.123457, c(%f)=12345678.123457, c(%8.4lf)=12345678.1235
d=p
d(%c)=p, d(%8c)= p
*/
scanf 函数
scanf 函数称为格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。
scanf 函数是一个标准库函数,它的函数原型在头文件 ”stdio.h” 中。scanf 函数的一般形式为:scanf(“格式控制字符串”, 地址表列)
scanf 函数格式控制字符串
格式字符串的一般形式为:%[*][输入数据宽度][长度]类型
类型
格式
字符意义
d
输入十进制整数
o
输入八进制整数
x
输入十六进制整数
u
输入无符号十进制整数
f 或 e
输入实型数(用小数形式或指数形式)
c
输入单个字符
s
输入字符串
* 符:用以表示该输入项,读入后不赋予相应的变量,即跳过该输入值。
#include<stdio.h>
int main(void)
{
int a,b;
scanf(“%d %*d %d”,&a,&b);// 当输入为:1 2 3 时,把 1 赋予 a,2 被跳过,3 赋予 b。
printf(“%d %d”,a,b);
return 0;
}
/*
执行结果:
2 4 5
2 5
*/
宽度
#include<stdio.h>
int main(void)
{
int a,b;
scanf(“%5d”,&a);// 输入 12345678 只把 12345 赋予变量 a,其余部分被截去。
printf(“%d”,a);
scanf(“%4d%4d”,&a,&b);// 输入 12345678 将把 1234 赋予 a,而把 5678 赋予 b。
printf(“%d %d”,a,b);
return 0;
}
长度:h 表示按短整型量输出,l 表示按长整型量输出。
地址列表
&a、&b 分别表示变量 a 和变量 b 的地址。这个地址就是编译系统在内存中给 a、b 变量分配的地址。
scanf 函数在本质上是给变量赋值,但要求写变量的地址,如 &a。& 是一个取地址运算符,&a 是一个表达式,其功能是求变量的地址。
注意事项
scanf 函数中没有精度控制,如:scanf(“%5.2f”,&a); 是非法的。不能企图用此语句输入小数为 2 位的实数。
scanf 中要求给出变量地址,如给出变量名则会出错。如 scanf(“%d”,a); 是非法的,应改为 scnaf(“%d”,&a); 才是合法的。
在输入多个数值数据时,若格式控制串中没有非格式字符作输入,数据之间的间隔则可用空格,TAB 或回车作间隔。C 编译在碰到空格,TAB,回车或非法数据 (如对 ”%d” 输入 ”12A” 时,A 即为非法数据) 时即认为该数据结束。
在输入字符数据时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。
#include <stdio.h>
int main(void)
{
char a,b;
printf(“input character a,b\n”);
scanf(“%c%c”,&a,&b);
printf(“%c%c\n”,a,b);
return 0;
}
/*
由于 scanf 函数 ”%c%c” 中没有空格,输入 M N,结果输出只有 M。而输入改为 MN 时则可输出 MN 两字符。
*/
编程实战
二进制转换为十进制
#include<stdio.h>
#include<math.h>
int main(void)
{
int x,a,result=0,i=0;
printf(“ 请输入仅有 4 位的二进制数:”);
scanf(“%d”,&x);
while(x!=0)
{
a = x%10;
result += a*pow(2.0,i);
i++;
x/=10;
}
printf(“ 对应的十进制数是:%d\n”,result);
return 0;
}
字符转换:大小写转换
#include<stdio.h>
int main(void)
{
char a,b,c;
printf(“ 请用户输入三个小写字母,输入时字母之间使用空格隔开:”);
scanf(“%c %c %c”,&a,&b,&c);
printf(“%c %c %c 相对应的 ASCII 码值为:%d %d %d\n”,a,b,c,a,b,c);
printf(“%c %c %c 相对应大写字母为:%c %c %c\n”,a,b,c,a-32,b-32,c-32);
return 0;
}
求三个数里面的最大值
int max(int x,int y,int z){
if(x>=y && x>=z)
return x;
else if(y>=x && y>=z)
return y;
else
return z;
}