知识点计算机软件,计算机软件水平考试《程序员》复习知识点(1)

常用输出格式符表

格式符 意 义

d或i 整型数据以十进制形式输出

o 无符号整型数据以八进制形式输出

X 无符号整型数据以十六进制形式输出

U 元符号整型数据以十进制形式输出

C 字符的ASCll码数据,输出对应的字符

S 输出字符串

f 以“整数部分。小数部分”形式输出实型数据

e 以[-]n.nnnnne±xx输出实型数据

g 以f或e格式输出

说明:(1)x格式符同。格式符一样,把符号位作为数的一部分输出。对于x格式,用字符a、b、c、d、e、f(或A、B、C、D、E、F)表示9之后的六个十六进制数字符。

(2)一个整数,只要它的位在0-255范围内,也可以用字符形式输出,输出以该整数为ASCII代码的字符。反之,一个字符数据也可以用整数形式输出,输出该字符的ASCII代码值。

(3)f、e和g格式符用于输出实型数据,格式转换时有四舍五人处理。对于f格式,小数点后的数字个数可由格式修饰说明p指定,若p为0,不显示小数点。用e格式输出时,对于非0实数,小数点前有一位非零数字,输出格式中的有效位数可由格式修饰说明p指定;字符e(或E)之后是指数,指数部分至少包含两个数字。若输出值的绝对值不小于 1E+100,则指数部分多于两位数字。

g格式能根据表示数据所需字符的多少自动选择f格式或e(或E) 格式输出实数,选择是以输出时所需字符数多少为标准。

格式修饰说明有七种,教材只介绍其中四种,它们的意义分别说明如下:

(1)W域宽说明,W是一个十进制整数,表示输出字段的字符数。若转换后需要的字符个数比给出的W多,则以实际需要为准;若转换后需要的字符数比W少,就在左边用填充字符补足(若给出左边对齐标志(-),则在右边补填充字符人通常用空白符作填充字符,若十进制整数W之前有前导0(此0不表示以八进制数给出字段宽度),则以字符0作填充字符。

(2)- 左对齐标志,当转换后字符个数少于W时,在W所限定的字段宽度内,转换所得字符列左对齐,右边补填充符。缺省时,右对齐,左边补填充符。

(3)。p,其中p也是十进制整数。

对于g或e格式输出,p指明输出精度(有效数字位数),可以缺省,缺省值依赖于系统的规定(下面的例子设p的缺省值为6)。

对于f格式输出,p指明输出字符列的小数点之后的数字个数,可以缺省。

对于S格式输出,p指明最多输出字符率的前p个字符,多余截断。缺省时,字符串的内容全部输出。

对于d.i、O、u、x和X,表示至少出现的数字个数。

同域宽说明一样,p也可以是字符*,而实际值由后面一个输出项的整数值给出,若该值为负值,相当于没有给出p.

(4) l指明输出项的类型。

长度修饰符l用于格式符d、i、o、u、X,表示对应的输出项是长整型或无符号长整型。

以下是格式输出的一些例子。例如,int i=1234; long j=1234567L;

printf(“%d,%+6d,d,%-6d, %5ld”,i,i,i,i,j)

将输出:1234,+1234,00l234,1234,1234567

注意:对于long型数据输出,必须在格式符之前有长度修饰符l,表明输出long型数据。

若 int k=045;long p=-1L;printf(“%#o,%4o,%6lo”,k,k,p)

将输出:045, 45, 37777777777

而printf(“%#x,%4x,%6lx”,k,k,p)将输出:0x25, 25, FFFFFFFF

若 unsigned int u= 65535u;prinif(“%d,%4u,%ln‘,u,u,p)

将输出:-l, 65535, 4294967295

若 char ch1= 045, ch2=‘a’;printf(“%c,%-3c,,”,ch1,ch2,ch2)

将输出:%,a, a

若 char s[]==“ABCDEF‘;printf(”%3s,%4.2s,%-7.4s,%.5s“,s,s,s,s)

将输出:ABCDEF, AB, ABCD, ABCDE

若 float f=123.4567f; double d=123.456789;

printf(“%。4f,%8.3f,%-7.2f,%。7f”,f,f,f,d)

将输出:123.4567, 123.457, 123.46, 123.4567890

而 printf(“%。6e,.2e,%-10.2e,%.2e,%.9e”,f,f, f,f,d)

将输出:1.23457e+02, 1.2e+02,1.2e+02,l.2e+02, 1.23456789e+02

注意:实型数据的有效位数,不要以为凡是打印(显示)的数字都是准确的。一般地,float型只有7位有效数字,double型有15位有效数字。实际上,因计算过程中的误差积累,通常不能达到所说的有效位数。]

另外,要注意%g格式的特殊性,当它选择“整数部分。小数部分”形式时,因格式修饰说明。p在e格式中的意义是指明精度,所以p的值是整数部分位数与小数部分位数之和(不是f格式中的小数位数)。如有

float g1=12.34f,g2=0.0f;

double d=123.456789, g=123456.789;

printf(“%g,%G”,g1,g2);

printf(“%f,%g,%g,%g,%.8g”‘,g1,g1,d,g,g)

将输出:

12.34,0

12.340000,12.34,123.457,123457,123456.79

相关推荐:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值