c语言输出整型量格式符,C语言输出格式(详细)

c语言输出整型量格式符,C语言输出格式(详细)C语言格式化输出一、printf()函数printf()函数是格式化输出函数,一般用于向标准输出设备按规定格式输出信息。在编写程序时经常会用到此函数。printf()函数的调用格式为:printf(“”,);其中格式化字符串包括两部分内容:一部分是正常字符,这些字符将按原样输出,另一部分是格式化规定字符,以”%”开始,后跟一个或几个规定字符用来确定输出内容格式。参量表是需要输出的一系列参数…

大家好,又见面了,我是你们的朋友全栈君。

C语言格式化输出

一、printf()函数

printf()函数是格式化输出函数,一般用于向标准输出设备按规定格式输出信息。在编写程序时经常会用到此函数。printf()函数的调用格式为: printf(“”, );

其中格式化字符串包括两部分内容:一部分是正常字符, 这些字符将按原样输出, 另一部分是格式化规定字符,以”%”开始,后跟一个或几个规定字符用来确定输出内容格式。

参量表是需要输出的一系列参数,其个数必须与格式化字符串所说明的输出参数个数一样多,各参数之间用”,”分开,且顺序一一对应,否则将会出现意想不到的错误。

二、 格式化规定符

Turbo C2.0提供的格式化规定符如下:

━━━━━━━━━━━━━━━━━━━━━━━━━━

符号 作用

——————————————————————————

%d 十进制有符号整数

%u 十进制无符号整数

%f 浮点数

%s 字符串

%c 单个字符

%p 指针的值

%e 指数形式的浮点数

%x, %X 无符号以十六进制表示的整数

%0 无符号以八进制表示的整数

%g 自动选择合适的表示法

━━━━━━━━━━━━━━━━━━━━━━━━━━

可以在”%”和字母之间插进数字表示最大场宽。

三、规定符说明

说明1:对于d%

(1)%md: 指定输出的宽度。数据位数小于m,左端补空格;大于m,按实际位数输出。比如说%3d 表示输出3位整型数,不够3位右对齐。

a=123;b=12345;

printf(“%4d,%4d”,a,b);

输出结果为:_123,12345

若想在输出值前加一些0, 就应在场宽项前加个0。例如%04d表示在输出一个小于4位的数值时,将在前面补0使其总宽度为4位。

(2)%ld: 输出长整型数据。比如下面的就不能用%d。

long a=123456;

printf(“%ld”,a);

printf(“%9ld”,a); 输出结果为:___123456

(3)%-md:

可以控制输出左对齐,即在”%”和字母之间加入一个”-” 号可,没有说明则右对齐。

比如:%-7d 表示输出7位整数左对齐

说明2:对于f%

(1)%m.nf

表示最大场宽m,小数位为n位,整数位则为m-n-1位,够m位右对齐。

比如:%9.2f 表示输出场宽为9的浮点数, 其中小数位为2,整数位为6,小数点占一位,不够9位右对齐。

(2)%-m.nf可以控制输出左对齐。

(3)%lf 表示输出double浮点数。

说明3:对于%s,%e同样道理

%-10s 表示输出10个字符左对齐,没有说明则右对齐。

%8s 表示输出8个字符的字符串,不够8个字符右对齐。

%6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9,则第9个字符以后的内容将被删除。

说明4:其它注意

(1)超过说明的场宽

如果字符串的长度或整型数位数超过说明的场宽,将按其实际长度输出。对浮点数,若整数部分位数超过了说明的整数位宽度,将按实际整数位输出。若小数部分位数超过了说明的小数位宽度,则按说明的宽度以四舍五入输出。

(2)浮点数表示字符或整型量的输出格式,如%6.9s 和%6.9d

如果用浮点数表示字符或整型量的输出格式,小数点后的数字代表最大宽度,小数点前的数字代表最小宽度。若大于最大宽度,则最大宽度以后的内容将被删除。

比如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9,则第9个字符以后的内容将被删除。

四、一些特殊字符

━━━━━━━━━━━━━━━━━━━━━━━━━━

字符 作用

——————————————————————————

\n 换行

\f 清屏并换页

\r 回车

\t Tab符

\xhh 表示一个ASCII码用16进表示,

其中hh是1到2个16进制数

━━━━━━━━━━━━━━━━━━━━━━━━━━

具体实现如下:

//%d 十进制有符号整数

//%u 十进制无符号整数

//%f 浮点数

//%s 字符串

//%c 单个字符

//%p 指针的值

//%e 指数形式的浮点数

//%g 自动选择合适的表示法

#include

#include

#include

using namespace std;

int main()

{

unsigned int a=23;

int b=234,h=4567;

double c=5.656;

long d=54;

float e=34.123456;

char f=’a’;

char g[10]={‘a’,’c’,’c’,’e’,’p’,’t’,’e’,’d’};

int *p=&b;

//%md: 指定输出的宽度。数据位数小于m,左端补空格;大于m,按实际位数输出

//比如说%3d 表示输出3位整型数,不够3位右对齐,输出结果为:____23

printf(“指定输出的宽度输出:a=%4d\n”,a);

//%ld: 输出长整型数据

printf(“输出长整型数据:d=%ld\n”,d);

printf(“指定输出的宽度输出长整型数据:d=%9ld\n”,d);

//%-md:可以控制输出左对齐,即在”%”和字母之间加入一个”-” 号可,没有说明则右对齐。

printf(“输出左对齐: b=%4d\n”,b);

printf(“输出左对齐: h=%4d\n”,h);

//%m.nf,表示最大场宽m,小数位为n位,整数位则为m-n-1位,够m位右对齐。

printf(“场宽m为9,小数为3位输出: e=%9.3f\n”,e);

//%-m.nf可以控制输出左对齐

printf(“场宽m为9,小数为3位,左对齐输出为: e=%9.3f\n”,e);

//%.nf,表示小数位为n位

printf(“小数为4位输出: e=%.4f\n”,e);

//%lf 表示输出double浮点数

printf(“double浮点数保留两位小数输出: c=%.2f\n”,c);

//%10s 表示输出6个字符的字符串,不够6个字符右对齐。

printf(“控制字符串6个字符的输出: g=%.6s\n”,g);

//%c单个字符输出

printf(“单个字符输出: f=%c\n”,f);

//%p 输出指针的值

printf(“指针的值输出: p=%p\n”,p);

//%e 指数形式的浮点数

printf(“指数形式的浮点数输出: e=%e\n”,e);

//%g 自动选择合适的表示法

printf(“double浮点数自动选择合适的表示法输出: c=%g\n”,c);

return 0;

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/163833.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Spark pool_spark docker

    Spark pool_spark docker概述这篇文章主要是分析一下Pool这个任务调度的队列。整体代码量也不是很大,正好可以详细的分析一下,前面在TaskSchedulerImpl提到大体的功能,这个点在丰富一下吧。DAGSchedul

    2022年8月4日
    3
  • python执行测试用例_java随机数random

    python执行测试用例_java随机数random前言通常我们认为每个测试用例都是相互独立的,因此需要保证测试结果不依赖于测试顺序,以不同的顺序运行测试用例,可以得到相同的结果。pytest默认运行用例的顺序是按模块和用例命名的ASCII编码

    2022年7月28日
    21
  • Keil(MDK-ARM)介绍、下载、安装与注册[通俗易懂]

    Keil(MDK-ARM)介绍、下载、安装与注册[通俗易懂]推荐分享一个大神的人工智能教程。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到人工智能的队伍中来!http://www.captainbed.net/strongerhuang推荐在我的公众号「strongerHuang」或网站(www.strongerhuang.com)阅读以下教程:Keil系列教程01_Keil介绍、下载、安装与注册Keil系列教程02_新建基础软件…

    2022年6月10日
    57
  • 程序猿必备的数电知识,快来看看你掌握多少!(建议收藏)

    程序猿必备的数电知识,快来看看你掌握多少!(建议收藏)目录????0.前言:????1.常见进制介绍:????(1)十进制:①示例:②可知一个任意多位的十进制数D均可展开为如下形式:③拓展——若以N取代式中的10,即可得到多位任意进制(N进制)数展开式的普遍形式:????(2)二进制:①根据N进制数展开的普遍形式可得任意一个二进制数均可展开为:![在这里插入图片描述](https://img-blog.csdnimg.cn/b7a289fac3d54c6f8ef071849945ca92.png)②并可利用上式计算出任一二进制数所表达的十进制数的大小:???

    2022年5月15日
    42
  • 路径规划-人工势场法(Artificial Potential Field)

    路径规划-人工势场法(Artificial Potential Field)人工势场法是局部路径规划的一种比较常用的方法。这种方法假设机器人在一种虚拟力场下运动。1.简介如图所示,机器人在一个二维环境下运动,图中指出了机器人,障碍和目标之间的相对位置。这个图比较清晰的说明了人工势场法的作用,物体的初始点在一个较高的“山头”上,要到达的目标点在“山脚”下,这就形成了一种势场,物体在这种势的引导下,避开障碍物,到达目标点。人工势场包括引力场合斥力场,其中目标点对物体产生引力,引导物体朝向其运动(这一点有点类似于A*算法中的启发函数h)。障碍物对物体产生斥力,..

    2022年6月22日
    41
  • springmvc过滤器和拦截器的区别_拦截器和过滤器的区别面试

    springmvc过滤器和拦截器的区别_拦截器和过滤器的区别面试SpringMVC中的过滤器和拦截器文章目录SpringMVC中的过滤器和拦截器一、过滤器二、拦截器三、小结一、过滤器​ 过滤器Filter是通过实现java.servlet.filter接口实现过滤器功能,作用是用于对传入的request和响应的response进行一些处理,比如对请求参数进行校验,或者设置、检验头部信息,再或者对一些非法行为进行校验。由实现的接口可知,过滤器是依赖于servlet容器。所以由于过滤器不依赖于spring容器,它也就无法获取到容器中的对象。创建一个过滤器类继承j

    2022年8月23日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号