c语言输入输出格式

c语言输入输出格式//最近被某题的输入输出卡了。。。转一波随时看。。。菜哭<spanstyle="font-family:KaiTi_GB2312;font-size:18px;">本小节介绍的是向标准输出设备显示器输出数据的语句。在C语言中,所有的数据输入/输出都是由库函数完成的。因此都是函数语句。本小节先介绍printf函数和putchar函数。printf函数printf函数称为格式输出函数,其…

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

//最近被某题的输入输出卡了。。。转一波随时看。。。菜哭

<span style="font-family:KaiTi_GB2312;font-size:18px;">本小节介绍的是向标准输出设备显示器输出数据的语句。在C语言中,所有的数据输入/输出都是由库函数完成的。因此都是函数语句。本小节先介绍printf函数和putchar函数。printf函数printf函数称为格式输出函数,其关键字最末一个字母f即为“格式”(format)之意。其功能是按用户指定的格式,把指定的数据显示到显示器屏幕上。  
一、printf函数调用的一般形式  
printf函数是一个标准库函数,它的函数原型在头文件“stdio.h”中。但作为一个特例,不要求在使用 printf 函数之前必须包含stdio.h文件。printf函数调用的一般形式为: printf(“格式控制字符串”,输出表列)其中格式控制字符串用于指定输出格式。格式控制串可由格式字符串和非格式字符串两种组成。格式字符串是以%开头的字符串,在%后面跟有各种格式字符,以说明输出数据的类型、形式、长度、小数位数等。如“%d”表示按十进制整型输出,“%ld”表示按十进制长整型输出,“%c”表示按字符型输出等。后面将专门给予讨论。  
非格式字符串在输出时原样照印,在显示中起提示作用。输出表列中给出了各个输出项,要求格式字符串和各输出项在数量和类型上应该一一对应。  
void main()  
{  
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);  
}  
a<--8,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);  
本例中四次输出了a,b的值,但由于格式控制串不同,输出的结果也不相同。第四行的输出语句格式控制串中,两格式串%d 之间加了一个空格(非格式字符),所以输出的a,b值之间有一个空格。第五行的printf语句格式控制串中加入的是非格式字符逗号,因此输出的a,b值之间加了一个逗号。第六行的格式串要求按字符型输出 a,b值。第七行中为了提示输出结果又增加了非格式字符串。  
二、格式字符串  
在Turbo C中格式字符串的一般形式为: [标志][输出最小宽度][.精度][长度]类型其中方括号[]中的项为可选项。各项的意义介绍如下:  
1.类型类型字符用以表示输出数据的类型,其格式符和意义下表所示:  
表示输出类型的格式字符       格式字符意义  
d                 以十进制形式输出带符号整数(正数不输出符号)  
o                 以八进制形式输出无符号整数(不输出前缀O)  
x                 以十六进制形式输出无符号整数(不输出前缀OX)  
u                 以十进制形式输出无符号整数  
f                 以小数形式输出单、双精度实数  
e                 以指数形式输出单、双精度实数  
g                 以%f%e中较短的输出宽度输出单、双精度实数  
c                 输出单个字符  
s                 输出字符串  
2.标志  
标志字符为-、+、#、空格四种,其意义下表所示:  
标志格式字符      标 志 意 义  
-           结果左对齐,右边填空格  
+          输出符号(正号或负号)  
空格                           输出值为正时冠以空格,为负时冠以负号  
#          对c,s,d,u类无影响;对o类, 在输出时加前缀0;  
对x类,在输出时加前缀0x;对e,g,f 类当结果有小数时才给出小数点  
3.输出最小宽度  
用十进制整数来表示输出的最少位数。 若实际位数多于定义的宽度,则按实际位数输出, 若实际位数少于定义的宽度则补以空格或0。  
4.精度  
精度格式符以“.”开头,后跟十进制整数。本项的意义是:如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。  
5.长度  
长度格式符为h,l两种,h表示按短整型量输出,l表示按长整型量输出。  
void main(){  
int a=15;  
float b=138.3576278;  
double c=35648256.3645687;  
char d='p';  
printf("a=%d,],%o,%x\n",a,a,a,a);  
printf("b=%f,%lf,%5.4lf,%e\n",b,b,b,b);  
printf("c=%lf,%f,%8.4lf\n",c,c,c);  
printf("d=%c,�\n",d,d);  
} a<--15  
b<--138.3576278  
c<--35648256.3645687  
d<--'p' main()  
{  
int a=29;  
float b=1243.2341;  
double c=24212345.24232;  
char c='h'  
printf("a=%d,],%o,%x\n",a,a,a,a);  
printf("b=%f,%lf,%5.4lf,%e\n",b,b,b,b);  
printf("c=%lf,%f,%8.4lf\n",c,c,c);  
printf("d=%c,�\n",d,d);  
}  
本例第七行中以四种格式输出整型变量a的值,其中“] ”要求输出宽度为5,而a值为15只有两位故补三个空格。第八行中以四种格式输出实型量b的值。其中“%f”和“%lf ”格式的输出相同,说明“l”符对“f”类型无影响。“%5.4lf”指定输出宽度为5,精度为4,由于实际长度超过5故应该按实际位数输出,小数位数超过4位部分被截去。第九行输出双精度实数,“%8.4lf ”由于指定精度为4位故截去了超过4位的部分。第十行输出字符量d,其中“� ”指定输出宽度为8故在输出字符p之前补加7个空格。  
使用printf函数时还要注意一个问题, 那就是输出表列中的求值顺序。不同的编译系统不一定相同,可以从左到右,也可从右到左。Turbo C是按从右到左进行的。如把例2.13改写如下述形式:  
void main(){  
int i=8;  
printf("%d\n%d\n%d\n%d\n%d\n%d\n",++i,--i,i--,i++,-i--);  
} i<--8  
这个程序与例2.13相比只是把多个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。但是必须注意,求值顺序虽是自右至左,但是输出顺序还是从左至右,因此得到的结果是上述输出结果。  
字符输出函数  
putchar 函数  
putchar 函数是字符输出函数, 其功能是在显示器上输出单个字符。其一般形式为: putchar(字符变量) 例如:  
putchar('A'); 输出大写字母A  
putchar(x); 输出字符变量x的值  
putchar('\n'); 换行 对控制字符则执行控制功能,不在屏幕上显示。 使用本函数前必须要用文件包含命令:  
#include<stdio.h>  
#include <stdio.h>  
void main(){  
char a='B',b='o',c='k';  
putchar(a);putchar(b);putchar(b);putchar(c);putchar('\t');  
putchar(a);putchar(b);  
putchar('\n');  
putchar(b);putchar(c);  
}  
数据输入语句  
C语言的数据输入也是由函数语句完成的。 本节介绍从标准输入设备—键盘上输入数据的函数scanf和getchar。 scanf函数 scanf函数称为格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。  
一、scanf函数的一般形式  
scanf函数是一个标准库函数,它的函数原型在头文件“stdio.h”中,与printf函数相同,C语言也允许在使用scanf函数之前不必包含stdio.h文件。scanf函数的一般形式为: scanf(“格式控制字符串”,地址表列); 其中,格式控制字符串的作用与printf函数相同,但不能显示非格式字符串,也就是不能显示提示字符串。地址表列中给出各变量的地址。地址是由地址运算符“&”后跟变量名组成的。例如,&a,&b分别表示变量a和变量b 的地址。这个地址就是编译系统在内存中给a,b变量分配的地址。在C语言中,使用了地址这个概念,这是与其它语言不同的。应该把变量的值和变量的地址这两个不同的概念区别开来。变量的地址是C编译系统分配的,用户不必关心具体的地址是多少。变量的地址和变量值的关系如下: &a--->a567 a为变量名,567是变量的值,&a是变量a的地址。在赋值表达式中给变量赋值,如: a=567 在赋值号左边是变量名,不能写地址,而scanf函数在本质上也是给变量赋值,但要求写变量的地址,如&a。这两者在形式上是不同的。&是一个取地址运算符,&a是一个表达式,其功能是求变量的地址。  
void main(){  
int a,b,c;  
printf("input a,b,c\n");  
scanf("%d%d%d",&a,&b,&c);  
printf("a=%d,b=%d,c=%d",a,b,c);  
}  
注意&的用法!  
在本例中,由于scanf函数本身不能显示提示串,故先用printf语句在屏幕上输出提示,请用户输入a、b、c的值。执行scanf语句,则退出TC屏幕进入用户屏幕等待用户输入。用户输入7、8、9后按下回车键,此时,系统又将返回TC屏幕。在scanf语句的格式串中由于没有非格式字符在“%d%d%d”之间作输入时的间隔,因此在输入时要用一个以上的空格或回车键作为每两个输入数之间的间隔。  
如: 7 8 9  
或  
7  
8  
9  
格式字符串  
格式字符串的一般形式为: %[*][输入数据宽度][长度]类型 其中有方括号[]的项为任选项。各项的意义如下:  
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。  
4.长度  
长度格式符为l和h,l表示输入长整型数据(如%ld) 和双精度浮点数(如%lf)。h表示输入短整型数据。  
使用scanf函数还必须注意以下几点:  
a. scanf函数中没有精度控制,如: scanf("%5.2f",&a); 是非法的。不能企图用此语句输入小数为2位的实数。  
b. scanf中要求给出变量地址,如给出变量名则会出错。如 scanf("%d",a);是非法的,应改为scnaf("%d",&a);才是合法的。  
c. 在输入多个数值数据时,若格式控制串中没有非格式字符作输入数据之间的间隔则可用空格,TAB或回车作间隔。C编译在碰到空格,TAB,回车或非法数据(如对“%d”输入“12A”时,A即为非法数据)时即认为该数据结束。  
d. 在输入字符数据时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。例如:  
scanf("%c%c%c",&a,&b,&c);  
输入为:  
d e f  
则把'd'赋予a, 'f'赋予b,'e'赋予c。只有当输入为:  
def  
时,才能把'd'赋于a,'e'赋予b,'f'赋予c。 如果在格式控制中加入空格作为间隔,如 scanf ("%c %c %c",&a,&b,&c);则输入时各数据之间可加空格。  
void main(){  
char a,b;  
printf("input character a,b\n");  
scanf("%c%c",&a,&b);  
printf("%c%c\n",a,b);  
}  
scanf("'C14F14%c%c",&a,&b);  
printf("%c%c\n",a,b); 由于scanf函数"%c%c"中没有空格,输入M N,结果输出只有M。  
而输入改为MN时则可输出MN两字符,见下面的输入运行情况: input character a,b  
MN  
MN  
void main(){  
char a,b;  
printf("input character a,b\n");  
scanf("%c %c",&a,&b);  
printf("\n%c%c\n",a,b);  
}  
scanf("%c %c",&a,&b); 本例表示scanf格式控制串"%c %c"之间有空格时, 输入的数据之间可以有空格间隔。e. 如果格式控制串中有非格式字符则输入时也要输入该非格式字符。  
例如:  
scanf("%d,%d,%d",&a,&b,&c); 其中用非格式符“ , ”作间隔符,故输入时应为: 5,6,7  
又如: scanf("a=%d,b=%d,c=%d",&a,&b,&c);  
则输入应为  
a=5,b=6,c=7g. 如输入的数据与输出的类型不一致时,虽然编译能够通过,但结果将不正确。  
void main(){  
int a;  
printf("input a number\n");  
scanf("%d",&a);  
printf("%ld",a);  
}  
由于输入数据类型为整型, 而输出语句的格式串中说明为长整型,因此输出结果和输入数据不符。如改动程序如下:  
void main(){  
long a;  
printf("input a long integer\n");  
scanf("%ld",&a);  
printf("%ld",a);  
}  
运行结果为:  
input a long integer  
1234567890  
1234567890 当输入数据改为长整型后,输入输出数据相等。  
键盘输入函数  
getchar函数getchar函数的功能是从键盘上输入一个字符。其一般形式为: getchar(); 通常把输入的字符赋予一个字符变量,构成赋值语句,如:  
char c;  
c=getchar();#include<stdio.h>  
void main(){  
char c;  
printf("input a character\n");  
c=getchar();  
putchar(c);  
}  
使用getchar函数还应注意几个问题:  
1.getchar函数只能接受单个字符,输入数字也按字符处理。输入多于一个字符时,只接收第一个字符。  
2.使用本函数前必须包含文件“stdio.h”。  
3.在TC屏幕下运行含本函数程序时,将退出TC 屏幕进入用户屏幕等待用户输入。输入完毕再返回TC屏幕。  
void main(){  
char a,b,c;  
printf("input character a,b,c\n");  
scanf("%c %c %c",&a,&b,&c);  
printf("%d,%d,%d\n%c,%c,%c\n",a,b,c,a-32,b-32,c-32);  
}  
输入三个小写字母  
输出其ASCII码和对应的大写字母。  
void main(){  
int a;  
long b;  
float f;  
double d;  
char c;  
printf("%d,%d,%d,%d,%d",sizeof(a),sizeof(b),sizeof(f)  
,sizeof(d),sizeof(c));  
}  
输出各种数据类型的字节长度。  
</span>  

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/163837.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 什么是kit_django reinhardt

    什么是kit_django reinhardt#介绍ImageKit是用于处理图像的Django应用程序。如果需要从原图上生成一个长宽为50×50的图像,则需要ImageKit。ImageKit附带了一系列图像处理器,用于调整大小和裁剪等常见

  • 安卓渗透测试工具_渗透测试包括哪些

    安卓渗透测试工具_渗透测试包括哪些0x00前言     伴随着移动互联网的高速发展,手机端走进普通大众的日常生活,这里我们将基于android系统介绍一些基本android渗透测试必备的使用工具。这些工具更多的是安装在android客户端。至于PC端,在后面会陆续介绍。这里建议先把手机root了,获得root权限。至于怎样root,每个品牌每个型号的手机各不同,可以自行百度或者参考你手机的官网。0x01系统管理

  • win10键盘全部没反应_Win10的键盘失灵解决办法

    win10键盘全部没反应_Win10的键盘失灵解决办法最近发现Win10的笔记本,键盘有点失灵,要么按了没反应,要么重复输入,很是恼火,以为是笔记本键帽坏了没弹起来,琢磨了下,发现是win10系统问题,赶紧记下来做笔记1、打开“设置”->”系统”->”电源和睡眠”->”其他电源设置”点击“选择电源按钮的功能”->”更改当前不可用的设置”->将启用快速启动取消勾选,保存修改退出。接下来右键我的电脑-&…

  • 启动了韩剧_startactivity

    启动了韩剧_startactivity一般来说当我们从launcher中启动一个应用进入到ActivityA中,系统会为这个应用生成一个新任务堆栈并置于前台,ActivityA被放入栈底,之后从ActivityA启动另一个ActivityB,如果不设置什么附加属性,ActivityB默认也放到和ActivityA这个堆栈中,这样当你按返回时,B出栈,A呈现出来了,这个应该很好理解。那现在假如ActivityA启动一个Service…

  • java前端开发自动生成器_一个简单实用的java代码生成器

    java前端开发自动生成器_一个简单实用的java代码生成器做现在这破项目boss还觉得进度慢,时间其实都浪费在了基础的CRUD上了,一个上午好不容易调通从action到service在到dao在到数据库的crud。工欲善其事必先利其器,有一款趁手的工具可有效提高开发效率,推荐一个简单实用的在线java代码生成器。代码生成器只是xjr快速开发框架功能的一部分。这款代码生成器是一款国内最新自主研发的JAVA代码自动生成器,目前来看这是一款十分赞的代码…

  • Mysql清空表中数据「建议收藏」

    Mysql清空表中数据「建议收藏」常用的清空数据表的SQL语句有如下两种deletefrom表名;truncatetable表名第一种方法是删除表中数据且主键ID是继续顺序排下去第二种方法是彻底清空表中数据把数据结构恢复至刚建表的时候数据全部清空从性能上讲测试了三千条数据deletefromtable比truncatetable表名效率要慢上一点。truncate清除数…

发表回复

您的电子邮箱地址不会被公开。

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