当前位置:编程学习 > C/C++ >>

求printf和scanf的具体用法以及举例 C语言 二级考试

答案:printf函数

格式:printf(格式控制,输出表列)
"格式控制"是用双引号括起来的字符串,包括格式说明和普通字符。格式说明是由"%"和格式字符组成,作用是将输出的数据转换成指定的格式输出。普通字符原样照印。
(1) d格式符。用来输出10进制整数,包括下面3种用法。
%d,格式符,按整型数的实际长度输出。
%md,m为指定的输出字段宽度。如果数据的位数小于m,右对齐,左补空格,若大于m,按实际位数输出。
%ld,输出长型数据。
(2)o格式符,以8进制形式输出整数。
(3)x格式符,以16进制形式输出整数。
(4)u格式符,以10进制形式输出无符号数。
(5)c格式符,输出一个字符。
(6)s格式符,用来输出一个字符串。
%s,按字符串的实际长度输出,包括下面4种用法。
%ms,m为指定的输出字段宽度,如果字符串的长度小于m,右对齐,左补空格,若大于m,按实际位数输出。
%-ms,m为指定的输出字段宽度,如果字符串的长度小于m,左对齐,右补空格,若大于m,按实际位数输出。
%m.ns,m为指定的输出字段宽度,n为输出字符数。如果nm,m自动取n值,保证n个字符正常输出。
%-m.ns,m为指定的输出字段宽度,n为输出字符数。如果nm,m自动取n值,保证n个字符正常输出。
(7)f格式符,用来输出实数,包括下面3种用法。
%f,整数部分全部输出并输出6位小数。
%m.n ,m为指定的输出字段宽度,n为小数位数。如果数值长度小于m,右对齐,左补空格。
%-m.n ,m为指定的输出字段宽度,n为小数位数。如果数值长度小于m,左对齐,右补空格。
(8)e格式符,以指数形式输出实数,包括下面3种用法。
%e,输出6位小数和5位指数部分共占13位。
%m.ne,m为指定的输出字段宽度,n为小数位数。如果数值长度小于m,右对齐,左补空格。
%-m.ne,m为指定的输出字段宽度,n为小数位数。如果数值长度小于m,左对齐,右补空格。
(9)g格式符,根据数值大小自动选取f格式或e格式输出。
表3-2 printf格式符

格式符 说明
d 以带符号的十进制形式输出整数
o 以8进制无符号形式输出整数
x 以16进制无符号形式输出整数
u 以无符号10进制形式输出整数
c 以字符形式输出,只输出一个字符
s 输出字符串
f 以小数形式输出单、双精度数
e 以标准指数形式输出单、双精度数
g 选用%f或%e格式中输出宽度较短的格式


表3-3 printf附加格式符

字符 说明
l 用于长整型数,可加在格式符d、o、x、u前面
M(代表一个正整数) 数据最小宽度
n(代表一个正整数) 对实数,表示输出n位小数;对字符串,表示截断的字符个数
- 输出的数字或字符左对齐

scanf函数

格式:scanf(格式控制,地址表列)
格式控制见表3-4和3-5。地址表列是由若干个地址组成的表列,可以是变量的地址或字符串的首地址。
表3-4 scanf格式符

格式符 说明
d 输入10进制整数
o 输入8进制整数
x 输入16进制整数
c 输入单字符
s 输入字符串
f 输入实数


表3-5 scanf附加格式符

字符 说明
l 用于输入长型数据以及双精度数据
h 用于输入整型数据
m(代表一个正整数) 指定输入数据所占宽度
* 输入数据读入后不赋给相应的变量

printf()函数
printf()函数是格式化输出函数, 一般用于向标准输出设备按规定格式输出
信息。在编写程序时经常会用到此函数。printf()函数的调用格式为:
printf("<格式化字符串>", <参量表>);
其中格式化字符串包括两部分内容: 一部分是正常字符, 这些字符将按原
样输出; 另一部分是格式化规定字符, 以"%"开始, 后跟一个或几个规定字符,
用来确定输出内容格式。
参量表是需要输出的一系列参数, 其个数必须与格式化字符串所说明的输出
参数个数一样多, 各参数之间用","分开, 且顺序一一对应, 否则将会出现意想
不到的错误。
1. 格式化规定符
Turbo C2.0提供的格式化规定符如下:
━━━━━━━━━━━━━━━━━━━━━━━━━━
符号 作用
──────────────────────────
%d 十进制有符号整数
%u 十进制无符号整数
%f 浮点数
%s 字符串
%c 单个字符
%p 指针的值
%e 指数形式的浮点数
%x, %X 无符号以十六进制表示的整数
%0 无符号以八进制表示的整数
%g 自动选择合适的表示法
━━━━━━━━━━━━━━━━━━━━━━━━━━
说明:
(1). 可以在"%"和字母之间易做图数字表示最大场宽。
例如: %3d 表示输出3位整型数, 不够3位右对齐。
%9.2f 表示输出场宽为9的浮点数, 其中小数位为2, 整数位为6,
小数点占一位, 不够9位右对齐。
%8s 表示输出8个字符的字符串, 不够8个字符右对齐。
如果字符串的长度、或整型数位数超过说明的场宽, 将按其实际长度输出。
但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出;
若小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出。
另外, 若想在输出值前加一些0, 就应在场宽项前加个0。
例如: %04d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度
为4位。
如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度,
小数点前的数字代表最小宽度。
例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 则
第9个字符以后的内容将被删除。
(2). 可以在"%"和字母之间加小写字母l, 表示输出的是长型数。
例如: %ld 表示输出long整数
%lf 表示输出double浮点数
(3). 可以控制输出左对齐或右对齐, 即在"%"和字母之间加入一个"-" 号可
说明输出为左对齐, 否则为右对齐。
例如: %-7d 表示输出7位整数左对齐
%-10s 表示输出10个字符左对齐
2. 一些特殊规定字符
━━━━━━━━━━━━━━━━━━━━━━━━━━
字符 作用
──────────────────────────
\n 换行
\f 清屏并换页
\r 回车
\t Tab符
\xhh 表示一个ASCII码用16进表示,
其中hh是1到2个16进制数
━━━━━━━━━━━━━━━━━━━━━━━━━━
由本节所学的printf()函数, 并结合上一节学习的数据类型, 编制下面的程
序, 以加深对Turbo C2.0数据类型的了解。
例1
#include<stdio.h>
#include<string.h>
int main()
{
char c, s[20], *p;
int a=1234, *i;
float f=3.141592653589;
double x=0.12345678987654321;
p="How do you do";
strcpy(s, "Hello, Comrade");
*i=12;
c='\x41';
printf("a=%d\n", a); /*结果输出十进制整数a=1234*/
printf("a=%6d\n", a); /*结果输出6位十进制数a= 1234*/
printf("a=%06d\n", a); /*结果输出6位十进制数a=001234*/
printf("a=%2d\n", a); /*a超过2位, 按实际值输出a=1234*/
printf("*i=%4d\n", *i); /*输出4位十进制整数*i= 12*/
printf("*i=%-4d\n", *i); /*输出左对齐4位十进制整数*i=12*/
printf("i=%p\n", i); /*输出地址i=06E4*/
printf("f=%f\n", f); /*输出浮点数f=3.141593*/
printf("f=6.4f\n", f); /*输出6位其中小数点后4位的浮点数
f=3.1416*/
printf("x=%lf\n", x); /*输出长浮点数x=0.123457*/
printf("x=%18.16lf\n", x);/*输出18位其中小数点后16位的长浮点
数x=0.1234567898765432*/
printf("c=%c\n", c); /*输出字符c=A*/
printf("c=%x\n", c); /*输出字符的ASCII码值c=41*/
printf("s[]=%s\n", s); /*输出数组字符串s[]=Hello, Comrade*/
printf("s[]=%6.9s\n", s);/*输出最多9个字符的字符串s[]=Hello,
Co*/
printf("s=%p\n", s); /*输出数组字符串首字符地址s=FFBE*/
printf("*p=%s\n", p); /* 输出指针字符串p=How do you do*/
printf("p=%p\n", p); /*输出指针的值p=0194*/
getch();
retunr 0;
}

scanf():

int scanf("<格式化字符串>", <参量表>);
这应该是scanf的标准形式。先说说关于他的返回值的问题

上一个:C语言进阶应该看什么书?是不是有分支的?
下一个:谭浩强的C语言程序设计的书有什么?

CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,