printf输出格式例子,关于c语言printf输出格式
printf输出格式例子,关于c语言printf输出格式详细介绍
本文目录一览: printf输出格式是什么?
C语言中,控制printf函数输出格式的是格式字符,printf没有直接打出2进制数的格式符,直接打出16进制的格式符是x格式符,即%x。
printf函数中输出的格式为printf("
",
),格式化字符串由格式控制、和输出表列两部分组成,其中格式控制包含格式声明和普通字符。
格式声明由“%”和格式字符组成,如%d、%f等。它的作用是将输出的数据类型转换为指定的格式然后输出。普通字符是需要在输出时原样输出的字符。
扩展资料
C语言printf函数格式字符:
1、%d,按整型数据的实际长度输出。
2、%md,m为指定的输出字段的宽度。
3、%ld,输出长整型数据。
4、o格式符,以八进制整型式输出整数。
5、x格式符,以十六进制数形式输出整数。
6、u格式符,用来输出unsigned型数据,即无符号数,以十进制形式输出。
7、c格式符,用来输出一个字符。
8、s格式符,用来输出一个字符串。
9、f格式符,用来输出实数(包括单双精度),以小数形式输出。
10、e格式符,以指数形式输出实数。
11、g格式符,用来输出实数,它根据数值的大小,自动选f格式或e格式(选择输出是占宽度较小的一种),且不输出无意义的零。
12、p格式符,用于变量地址的输出。
13、%[scanfset]:
scanfset 有两种形式:一种是以非 “^” 字符开头的 scanset , 表示在读入字符串时将匹配所有在 scanfset 中出现的字符,遇到非scanfset 中的字符时输入就结束;
另外一种形式是以 “^” 字符开头的scanfset ,表示在读入字符串时将匹配所有不在scanfset 中出现的字符,遇到scanfset 中的字符输入就结束。
参考资料来源:百度百科——格式字符
参量表>
格式化字符串>
C语言中无符号长整型数的输入输出格式是什么
C语言中无符号长整型数的输入输出格式%u。
示例:
intmain()
{
unsignedinta;
intb=-1;
a=b;
printf(“%u”,a);
}
扩展资料
c语言printf()输出格式
%p指针
%s字符串
%%"%"
%a(%A)浮点数、十六进制数字和p-(P-)记数法(C99)
%c字符
%d有符号十进制整数
%f浮点数(包括float和doulbe)
%e(%E)浮点数指数输出[e-(E-)记数法]
%g(%G)浮点数不显无意义的零"0"
%i有符号十进制整数(与%d相同)
%o八进制整数e.g.0123
%x(%X)十六进制整数
()e.g.0x1234
printf中的%c,%d,%u........都分别代表输出的是什么类型的?
printf中%表示格式化输出,不同标志代表输出不同的类型数据。
%c代表输出单个字符,%d代表输出十进制整数,%u代表输出无符号十进制数,具体例子见下图:
扩展资料:
%表示格式化字符串输出,目前printf支持以下格式的输出:
与printf对应,scanf支持上述格式的输入。
参考资料:
C语言百度百科
手册网c/c++语言参考手册
%c代表输出单个字符。
%d代表输出十进制整数。
%u代表输出无符号十进制数。
输出十进制整数应该用%d。
C语言是一门通用计算机编程语言,应用广泛。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。
尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译,甚至包含一些嵌入式处理器(单片机或称MCU)以及超级电脑等作业平台。
二十世纪八十年代,为了避免各开发厂商用的C语言语法产生差异,由美国国家标准局为C语言制定了一套完整的美国国家标准语法,称为ANSI C,作为C语言最初的标准。[1] 目前2011年12月8日,国际标准化组织(ISO)和国际电工委员会(IEC)发布的C11标准是C语言的第三个官方标准,也是C语言的最新标准,该标准更好的支持了汉字函数名和汉字标识符,一定程度上实现了汉字编程。
C语言是一门面向过程的计算机编程语言,与C++,Java等面向对象的编程语言有所不同。
%d 十进制有符号整数
%u 十进制无符号整数
%f 浮点数
%s 字符串
%c 单个字符
%p 指针的值
%e 指数形式的浮点数
%x, %x 无符号以十六进制表示的整数
%0 无符号以八进制表示的整数
%g 自动选择合适的表示法
printf中分别代表的输出类型:
(%表示格式化输出)
%a(%A):浮点数、十六进制数字和p-(P-)记数法(C99)
%c:字符
%d:有符号十进制整数
%f:浮点数(包括float和doulbe)
%e(%E):浮点数指数输出[e-(E-)记数法]
%g(%G):浮点数不显无意义的零"0"
%i:有符号十进制整数(与%d相同)
%u:无符号十进制整数
%o:八进制整数
%x(%X):十六进制整数0f(0F)
%p:指针
%s:字符串
%d是十进制数,%c是字符型数,%u是无符号数
printf中分别代表的输出类型:
%a(%A):浮点数、十六进制数字和p-(P-)记数法(C99)
%c:字符
%d:有符号十进制整数
%f:浮点数(包括float和doulbe)
%e(%E):浮点数指数输出[e-(E-)记数法]
%g(%G):浮点数不显无意义的零"0"
%i:有符号十进制整数(与%d相同)
%u:无符号十进制整数
%o:八进制整数 e.g. 0123
%x(%X):十六进制整数0f(0F) e.g. 0x1234
%p:指针
%s:字符串
%%:"%"
扩展语句:
C语言中printf语句的简介:
printf()是C语言标准库函数,用于将格式化后的字符串输出到标准输出。标准输出,即标准输出文件,对应终端的屏幕。printf()申明于头文件stdio.h。
函数原型:int printf ( const char * format, ... );
返回值:
正确返回输出的字符总数,错误返回负值,与此同时,输入输出流错误标志将被置值,可由指示器ferror来检查输入输出流的错误标志。
调用格式:
printf()函数的调用格式为:printf("格式化字符串",输出表列)。
格式化字符串包含三种对象,分别为:
(1)字符串常量;
(2)格式控制字符串;
(3)转义字符。
字符串常量原样输出,在显示中起提示作用。输出表列中给出了各个输出项,要求格式控制字符串和各输出项在数量和类型上应该一一对应。其中格式控制字符串是以%开头的字符串,在%后面跟有各种格式控制符,以说明输出数据的类型、宽度、精度等。
参考资料:百度百科-C语言
CSDN论坛-printf语句详解
printf的格式
printf("%5.3f",125);
按语法规则,%f
用于float数,125
要写成浮点数:
printf("%5.3f",125.0);
5.3
意思是场宽5个字符,小数点下3位,场宽不够则按实际需要输出
应打印出
125.000
printf("%3.1f",25.796);
小数点下1位,后面的4舍5入,打印
25.8
printf("%5.2f",25.796);
小数点下2位,后面的4舍5入,
打印
25.80
printf("%5.2f",1.25);
小数点下2位,场宽5个字符(包括数字,小数点,负数还要包括-号)。
场宽不够则按实际需要输出,太宽则填空白。
printf("%5.2f",125.
);
小数点下2位,场宽5个字符,
125.00
,
场宽不够则按实际需要输出,太宽则填空白。
c语言中printf的用法
c语言中printf的用法的用法你知道吗?下面我就跟你们详细介绍下c语言中printf的用法的用法,希望对你们有用。
c语言中printf的用法的用法如下:
Printf和Scan函数的使用方法
一 printf()函数是格式化输出函数, 一般用于向标准输出设备按规定格式输出
信息。在编写程序时经常会用到此函数。printf()函数的调用格式为:
printf("
",
);
其中格式化字符串包括两部分内容: 一部分是正常字符, 这些字符将按原
样输出; 另一部分是格式化规定字符, 以"%"开始, 后跟一个或几个规定字符,
用来确定输出内容格式。
参量表是需要输出的一系列参数, 其个数必须与格式化字符串所说明的输出
参数个数一样多, 各参数之间用","分开, 且顺序一一对应, 否则将会出现意想
不到的错误。
格式化字符串的格式是:
%[标志][输出最小宽度][.精度][长度]格式字符
1. 标志:标志字符为-、+、#、空格四种,其意义下表所示:
标志 意义
- 结果左对齐,右边填空格
+ 输出符号(正号或负号)
空格 输出值为正时冠以空格,为负时冠以负号
# 对c,s,d,u类无影响;对o类,在输出时加前缀o;对x类,在输出时加前缀0x;对e,g,f 类当结果有小数 时才给出小数点(??????)
例1:
#i nclude
main()
{
int a=100;
float b=123.255;
printf("a=%d ",a);
printf("a=d ",a);
printf("a=%-10d ",a);
printf("a=%+d ",a);
printf("a=% d ",a);
printf("a=%#o ",a);
printf("a=%#x ",a);
printf("b=%#f ",b);
}
运行结果
a=100
a= 100
a=100
a=+100
a= 100
a=0144
a=0x64
b=123.254997 (?????)
2.输出最小宽度:用十进制整数来表示输出的最少位数。(至少要输出这么多位!)
若实际位数多于定义的宽度:则按实际位数输出。
若实际位数少于定义的宽度:则右对齐,左边留空。
有负号,左对齐,右边留空
表示宽度的数字以0开始,则右对齐,左边留空。
例2 #i nclude
main()
{
int a=3456;
printf("a== ",a); //若实际位数多于定义的宽度:则按实际位数输出
printf("a=d ",a); //若实际位数少于定义的宽度:则右对齐,左边留空
printf("a=%-10d ",a); //若实际位数少于定义的宽度:有负号,左对齐,右边留空
printf("a=0d ",a); //若实际位数少于定义的宽度:表示宽度的数字以0开始,则右对齐,左边留空
printf("a=%-010d ",a); //左对齐,0无意义。
}
运行结果:
a=3456
a= 3456
a=3456
a=0000003456
a=3456
3.精度:精度格式符以“.”开头,后跟十进制整数。意义是:
如果输出数字,则表示小数的位数;若实际位数大于所定义的精度数,则四舍五入。若不足则补0;
如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。
例3:
#i nclude
main()
{
printf("%.3f ",12.3456);
printf("%.9f ",12.3456);
printf("%.3s ","abcdefg");
printf("%.9s ","abcdefg");
}
运行结果:
12.346 //四舍五入到小数点后三位
12.345600000 //不足补0
abc
abcdefg
4.长度:长度格式符为h,l两种,h表示按短整型量输出,l表示按长整型量输出?????
5.Turbo C2.0提供的格式字符如下:
━━━━━━━━━━━━━━━━━━━━━━━━━━
符号 作用
──────────────────────────
%c 单个字符
%d 十进制有符号整数
%e 以“科学记数法”的形式输出十进制的浮点数 如2.451e+02
%f 输出十进制浮点数,不带域宽时,保留6位小数
%g 选用e或f格式中较短的一个输出十进制浮点数,不输出无效零
%0 无输出无符号八进制整数
%p 指针的值
%s 输出字符串
%u 输出无符号十进制整数
%x, %X 输出无符号十六进制整数 (不输出前缀Ox)
━━━━━━━━━━━━━━━━━━━━━━━━━━
2. 一些特殊规定字符
━━━━━━━━━━━━━━━━━━━━━━━━━━
字符 作用
──────────────────────────
换行
f 清屏并换页
回车
Tab符
xhh 表示一个ASCII码用16进表示,
其中hh是1到2个16进制数
━━━━━━━━━━━━━━━━━━━━━━━━━━
使用这些转义字符时不需要加上%,可单独使用!
由本节所学的printf()函数, 并结合上一节学习的数据类型, 编制下面的程
序, 以加深对Turbo C2.0数据类型的了解。
例1
#i nclude
#i nclude
int main()
{
char c, s[20], *p;
int a=1234, *i;
float f=3.138009;
double x=0.12345678987654321;
p="How do you do";
strcpy(s, "Hello, Comrade");
*i=12;
c='x41';
printf("a=%d ", a);
printf("a=m ", a);
printf("a=d ", a);
printf("a=- ", a);
printf("*i=M ", *i);
printf("*i=%-4d ", *i);
printf("i=%p ", i);
printf("f=%f ", f);
printf("f=6.4f ", f);
printf("x=%lf ", x);
printf("x=.16lf ", x);
printf("c=%c ", c);
printf("c=%x ", c);
printf("s[]=%s ", s);
printf("s[]=%6.9s ", s);
printf("s=%p ", s);
printf("*p=%s ", p);
printf("p=%p ", p);
getch();
retunr 0;
}
其他需要注意的一些问题:
1.如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度,
小数点前的数字代表最小宽度。
例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 则第9个字符以后的内容将被删除。
2.使用printf函数时还要注意一个问题,那就是输出表列中的求值顺序。不同的编译系统不一定相同,可以从左到右,也可从右到左。Turbo C是按从右到左进行的。请看下面两个例子:
例1
main(){
int i=8;
printf("%d %d %d %d %d %d ",++i,--i,i++,i--,-i++,-i--);
}
运行结果
8
7
7
8
-7
-8
例2
main(){
int i=8;
printf("%d ",++i);
printf("%d ",--i);
printf("%d ",i++);
printf("%d ",i--);
printf("%d ",-i++);
printf("%d ",-i--);
}
运行结果:
9
8
8
9
-8
-9
这两个程序的区别是用一个printf语句和多个printf 语句输出。但从结果可以看出是不同的。为什么结果会不同呢?就是因为printf函数对输出表中各量求值的顺序是自右至左进行的。在第一例中,先对最后一项“-i--”求值,结果为-8,然后i自减1后为7。 再对“-i++”项求值得-7,然后i自增1后为8。再对“i--”项求值得8,然后i再自减1后为7。再求“i++”项得7,然后i再自增1后为8。 再求“--i”项,i先自减1后输出,输出值为7。 最后才求输出表列中的第一项“++i”,此时i自增1后输出8。
但是必须注意,求值顺序虽是自右至左,但是输出顺序还是从左至右,因此得到的结果是上述输出结果。
补充:最近在调试程序时发现一段代码如下:
printf(sFormat,"%%0?",THE_NUMBER_LEN);
输出数组后发现sFormat = d;其中宏THE_NUMBER_LEN定义的为4,发现如果需要通过在printf转化的数组中出现%,那么就使用%%来代替,且后面的所有字符都会直接放入sFormat数组中一直遇到新的%。只有碰到“%+特定字符”,才会把右边对应的变量放入进来。
例如: printf(sFormat,"ABC%%d%d%%s?bc",THE_NUMBER_LEN,6);输出为ABC?%s6abc;
还有就是发现如果是修改成%0?,输出的字符串就变成 ?,这样我猜想就是在printf函数时,碰到第一个%0后知道再遇见下一个%前,如果中间没有特定字符d,s,e,f等,通通变成空格,而我在%中间增加两个的非特殊字符后,发现?前面的空格急剧增加,原因就不清楚。故两%之间不能增加其他非特殊字符。
二 Scan函数
数
scanf()函数是格式化输入函数, 它从标准输入设备(键盘) 读取输入的信息。
其调用格式为:
scanf("
",
);
格式化字符串包括以下三类不同的字符;
1. 格式化说明符: 格式化说明符与printf()函数中的格式说明符基本相同。
2. 空白字符: 空白字符会使scanf()函数在读操作中略去输入中的一个或多
个空白字符。
3. 非空白字符: 一个非空白字符会使scanf()函数在读入时剔除掉与这个非
空白字符相同的字符。
注意:(1)地址表是需要读入的所有变量的地址, 而不是变量本身:
----如果是一般的变量,通常要在变量名前加上"&";但输出时是用变量名
----如果是数组,用数组名就代表了该数组的首地址;输出时也是用数组名
----如果是指针,直接用指针名本身,不要加上“*”;输出时也用该指针即可。
例1:
各个变量的地址之间同","分开。
main()
{
int i;
char *p, str[20];
scanf("%d", &i);
scanf("%s", p);
scanf("%s", str);
printf("i=%d ",i);
printf("%s ", p);
printf("%s ", str);
}
(2)scanf函数中是否包含空白/非空白字符导致输入格式的不同
如:scanf("%d,%d",&i,&j); scanf中有,所以输入的格式应该是5,6==>i=5,j=6
scanf("%d%d",&i,&j); 可以用空格或回车来分隔两个输入 如 5 6==>i=5,j=6
scanf("%d %d",&i,&j); 同上
(3) 实际使用scanf()函数时存在一个问题, 下面举例进行说明:
当使用多个scanf()函数连续给多个字符变量输入时, 例如:
main()
{
char c1, c2;
scanf("%c", &c1);
scanf("%c", &c2);
printf("c1 is %c, c2 is %c", c21, c2);
}
运行该程序, 输入一个字符A后回车 (要完成输入必须回车), 在执行scanf
("%c", &c1)时, 给变量c1赋值"A", 但回车符仍然留在缓冲区内, 执行输入语句
scanf("%c", &c2)时, 变量c2输出的是一空行, 如果输入AB后回车, 那么输出结
果为: c1 is A, c2 is B。
要解决以上问题, 可以在输入函数前加入清除函数fflush()( 这个函数的使
用方法将在本节最后讲述)。修改以上程序变成:
#i nclude
main()
{
char c1, c2;
scanf("%c", &c1);
fflush(stdin);
scanf("%c", &c2);
printf("c1 is %c, c2 is %c", c1, c2);
}
在输入字符数据时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。
例如:scanf("%c%c%c",&a,&b,&c);
输入为:d e f
则把'd'赋予a, ' ' 赋予b,'e'赋予c。
只有当输入为: def
时,才能把'd'赋于a,'e'赋予b,'f'赋予c。
如果在格式控制中加入空格作为间隔,
如:scanf ("%c %c %c",&a,&b,&c);
则输入时各数据之间可加空格。
例4
main(){
char a,b;
printf("input character a,b ");
scanf("%c%c",&a,&b);
printf("%c%c ",a,b);
}
由于scanf函数"%c%c"中没有空格,输入M N,结果输出只有M。而输入改为MN时则可输出MN两字符。
(4)格式字符串的一般形式为:
%
[输入数据宽度][长度]类型
其中有方括号[]的项为任选项。各项的意义如下:
1)类型:表示输入数据的类型,其格式符和意义如下表所示。
格式 字符意义
d 输入十进制整数
o 输入八进制整数
x 输入十六进制整数
u 输入无符号十进制整数
f或e 输入实型数(用小数形式或指数形式)
c 输入单个字符
s 输入字符串
2)“*”符:用以表示该输入项,读入后不赋予相应的变量,即跳过该输入值。
如:scanf("%d %*d %d",&a,&b);
当输入为:1 2 3时,把1赋予a,2被跳过,3赋予b。
3)宽度:用十进制整数指定输入的宽度(即字符数)。
例如:
scanf("]",&a);
输入:12345678
只把12345赋予变量a,其余部分被截去。
又如:scanf("MM",&a,&b);
输入:12345678
将把1234赋予a,而把5678赋予b。
例:
main()
{
int a,b;
scanf("MM",&a,&b);
printf("a=%d,b=%d",a,b);
}
输入 12345 67890
运行结果 a=1234,b=5
4) 长度:长度格式符为l和h,l表示输入长整型数据(如%ld) 和双精度浮点数(如%lf)。h表示输入短整型数据。
使用scanf函数还必须注意以下几点:
1)scanf函数中没有精度控制,如:scanf("%5.2f",&a);是非法的。不能企图用此语句输入小数为2位的实数。
2)在输入多个数值数据时,若格式控制串中没有非格式字符作输入数据之间的间隔则可用空格,TAB或回车作间隔。C编译在碰到空格,TAB,回车或非法数据(如对“%d”输入“12A”时,A即为非法数据)时即认为该数据结束。
地址表>
格式化字符串>
参量表>
格式化字符串>
System.out.printf(%12.3f,%12.8f,d,d); 输出格式的12指的是什么,具体点,有例子
题目就是给你一个double型的数,我书上写的是123456.783124
输出格式化12就是说输出以后,加上小数点那些有12位,所以按我这个数据来说,第一个%12.3f就是输出12位并且小数点后面留3位,也就是123456.783;第二个就是123456.78312 懂了吗
%12.3f (表示输出共12个字符,包括小数点,并且小数点后面只有3位数)
C语言怎么用printf输出字符串。
void main()
{
unsigned char *x = "ab,sdf,sad,23432,cc";
data = x;
printf("data = %c\n", *data);
printf("data = %s\n", data);
system("pause");
}
扩展资料:printf输出字符串的一些格式
1、原样输出字符串:printf("%s", str);
2、输出指定长度的字符串, 超长时不截断, 不足时右对齐:printf("%Ns", str);
注:N 为指定长度的10进制数值
3、输出指定长度的字符串, 超长时不截断, 不足时左对齐:printf("%-Ns", str);
注:N 为指定长度的10进制数值
4、输出指定长度的字符串, 超长时截断, 不足时右对齐:printf("%N.Ms", str);
注:N 为最终的字符串输出长度
M 为从参数字符串中取出的子串长度
5、输出指定长度的字符串, 超长时截断, 不足时左对齐是: printf("%-N.Ms", str);
注:N 为最终的字符串输出长度
M 为从参数字符串中取出的子串长度
参考资料来源:printf-百度百科
printf函数的一般使用形式为:printf("输出格式",输出项系列);要输出字符串,则只需写出相应的输出格式以及输出项系列即可,其中输出格式为%s,输出项系列为字符串名
printf函数输出字符串的例子如下:
#include
void main()
{
char str[10]="ABCD";
printf("%s",str);
}
上述程序输出了字符串 ABCD
printf函数的一般使用形式为:printf("输出格式",输出项系列);要输出字符串,则只需写出相应的输出格式以及输出项系列即可,其中输出格式为%s,输出项系列为字符串名。
printf函数输出字符串的例子如下:
#include
void main()
{char str[10]="ABCD";
printf("%s",str);}
上述程序输出了字符串 ABCD
列子如下:
#include
struct student{
char a[20];
char id[20];
};
int main(void)
{
struct student stu1;
printf("请输入一个字符串...\n");
scanf("%s",stu1.a);
printf("输入的字符串是:\n");
printf("%s",stu1.a);
}
开中文DOS环境,你的程序就可以输出中文。 (Win-TC 1.91自带中文环境,可以下载用一下。)
英文DOS环境,你看到的是乱码。
没有中文环境,用printf不能输出汉字
一种取巧的办法是,自己构造"你好"的点阵字模(也可以使用现成的点阵汉字库),然后用printf("@")输出点阵,可以看到巨大的"你好"
图形模式下可以使用点阵汉字库输出中文,不过那不是用printf实现的
C语言怎么用printf输出字符串printf函数的一般格式printf(格式控制字符串,输出表列);以图1所示为例。图1.
函数参数包括两部分:【1】格式控制字符串,是用双引号括起来的字符串,也称为转换控制字符串,它指定输出数据项的类型和格式。它包括两种信息:
●格式说明项:由%和格式字符组成,如%d,%f等。格式说明总是由%字符开始,到格式字符终止。它的作用是将输出的数据项转换为指定的格式输出。输出表列中的每个数据项对应一个格式说明项。
● 普通字符:即需要原样输出的字符,如逗号和换行符。
【2】输出列表,是需要输出的一些数据项,可以是表达式。例如:假如a=3,b=4,那么printf("a=%db=%d",a,b);,输出a=3b=4。其中两个 “%d”是格式说明,表示输出两个整数,分别对应变量a,b。“a=”,“b=”是普通字符,原样输出。
由于printf是函数,因此,格式控制字符串和输出表列实际上都是函数的参数。printf函数的一般形式可以表示为:printf(参数1,参数2,参数3,…,参数n)
printf函数的功能是将参数2到参数n按照参数1给定的格式输出。
【3】格式字符 (构成格式说明项)对于不同类型的数据项,应当使用不同的格式字符构成的格式说明项。常用的有以下几种格式字符:(按不同类型数据,列出各种格式字符的常用用法)
【d格式符】用来输出十进制整数。有以下几种用法:● %d,按照数据的实际长度输出。● %md,m指定输出字段的宽度 (整数)。如果数据的位数小于m,则左端补以空格(右对齐);若大于m,则按照实际位数输出。● %-md,m指定输出字段的宽度 (整数)。如果数据的位数小于m,则右端补以空格 (左对齐);若大于m,则按照实际位数输出。● %ld,输出长整型数据,也可以指定宽度%mld。
【o格式符】以八进制形式输出整数。注意:是将内存单元中的各位的值按八进制形式输出,输出的数据不带符号,即将符号位也一起作为八进制的一部分输出。
例如:inta=-1;printf("%d,%o,%x",a,a,a);-1的原码:1000,0000,0000,0001。-1在内存中的补码表示为:1111,1111,1111,1111=1,111,111,111,111,111=1,7,7,7,7,7=ffff输出:-1,177777,ffff
【s格式符】用来输出一个字符串。有以下几种用法:● %s,输出字符串。● %ms,输出的字符串占m列,如果字符串长度大于m,则字符串全部输出;若字符串长度小于m,则左补空格 (右对齐)。● %-ms,输出的字符串占m列,如果字符串长度大于m,则字符串全部输出;若字符串长度小于m,则右补空格 (左对齐)。● %m.ns,输出占m列,但只取字符串左端n个字符,左补空白 (右对齐)。● %-m.ns,输出占m列,但只取字符串左端n个字符,右补空白 (左对齐)。
【 f 格式符】用来输出实数 (包括单、双精度,单双精度格式符相同),以小数形式输出。有以下几种用法:● %f,不指定宽度,使整数部分全部输出,并输出6位小数。注意,并非全部数字都是有效数字,单精度实数的有效位数一般为7位 (双精度16位)。● %m.nf,指定数据占m列,其中有n位小数。如果数值长度小于m,左端补空格(右对齐)。● %-m.nf,指定数据占m列,其中有n位小数。如果数值长度小于m,右端补空格(左对齐)。
【 e 格式符】以指数形式输出实数。可用以下形式表示:● %e,不指定输出数据所占的宽度和小数位数,由系统自动指定。如6位小数,指数占5位,-e占1位,指数符号占1位,指数占3位。数值按照规格化指数形式输出 (小数点前必须有而且只有1位非0数字)。
printf的格式
printf("%5.3f",125);
按语法规则,%f 用于float数,125 要写成浮点数:
printf("%5.3f",125.0); 5.3 意思是场宽5个字符,小数点下3位,场宽不够则按实际需要输出
应打印出 125.000
printf("%3.1f",25.796); 小数点下1位,后面的4舍5入,打印 25.8
printf("%5.2f",25.796); 小数点下2位,后面的4舍5入, 打印 25.80
printf("%5.2f",1.25); 小数点下2位,场宽5个字符(包括数字,小数点,负数还要包括-号)。
场宽不够则按实际需要输出,太宽则填空白。
printf("%5.2f",125. ); 小数点下2位,场宽5个字符, 125.00 , 场宽不够则按实际需要输出,太宽则填空白。
printf("[%d%*d%d*]\n", a, a, a);
第一个*号是个要输入的参数,第二个*号是显示出来的字符。
打印格式%d表示以十进制数打印
%10d表示以十进制数打印,但长度是十,左补空格.
%*d表示以十进制数打印,但长度由一个长度参数控制,左补空格
int len=10;
int b=5;
printf("[%*d]",len,b);/*len就是传给*号的参数,表示打印长度,b就是实际要显示的数据*/
打印结果是
[ 5]
关于c语言printf输出格式
printf("%5.3f",125);
按语法规则,%f 用于float数,125 要写成浮点数:
printf("%5.3f",125.0); 5.3 意思是场宽5个字符,小数点下3位,场宽不够则按实际需要输出
应打印出 125.000
printf("%3.1f",25.796); 小数点下1位,后面的4舍5入,打印 25.8
printf("%5.2f",25.796); 小数点下2位,后面的4舍5入, 打印 25.80
printf("%5.2f",1.25); 小数点下2位,场宽5个字符(包括数字,小数点,负数还要包括-号)。
场宽不够则按实际需要输出,太宽则填空白。
printf("%5.2f",125. ); 小数点下2位,场宽5个字符, 125.00 , 场宽不够则按实际需要输出,太宽则填空白。
第一个你写的不是全部把,输出结果是不是1.250E2?
第二个,printf("%3.1f",25.796);结果25.8
总之,规则就是,比如3.1f,表示共三位,其中小数点后1位。
#include
void main(){ printf("%5.3f",(float)125); printf("\n"); printf("%3.1f",1.25); printf("\n"); printf("%3.1f",25.796); printf("\n"); printf("%3.1f",(float)125); printf("\n"); printf("%5.2f",25.796); printf("\n"); printf("%5.2f",1.25); printf("\n"); printf("%5.2f",(float)125);}
以上是我照你的题目写的程序,还有输出的结果
例如%5.3f这种格式是控制输出格式的
f表示输出浮点数,5表示最小输出字符宽度为5位数(小数点占一位,比5位长的按实际输出,比5位短的前面补空白)3表示浮点数输出小数点后为3位数
你里面的125是整型,要做浮点型强制转换,也就是(float)125