printf和scanf同时使用,C语言scanf和printf的使用问题
printf和scanf同时使用,C语言scanf和printf的使用问题详细介绍
本文目录一览: c语言代码 如何实现scanf与printf在同一行执行
直接将scanf语句作为表达式放入printf语句中,
例如
int a;
printf("%d\n",scanf("%d",&a));
先写一个scanf语句,然后以分号结束,再写一个printf语句,完事。
我们平时的分行是为了提高代码的可读性,不要太拘泥。
理论上来讲,C语言是很灵活的,你只要将代码结束时的":"敲出来,完全可以在同一行执行,C语言最大的好处就在着了,它不需要在格式上画太大的功夫,但是,不提倡这样做,原因是你编写的程序是要让别人看的,还是漂亮一点比较好的
C语言键盘输入SCANF然后printf输出
1、第一个和第二个应该是一样的,都可以用字符串保存,然后输出
#include
int main(){ char str[1024]; scanf("%s", str); printf("%s\n", str);}2、小写转大写和大写转小写原理相同,将代码中的转大写部分注释掉,转小写部分取消注释就可以实现3和4的两个代码了
#include
int main(){ char str[1024]; scanf("%s", str); for (int i = 0; str[i]!='\0'; i++){ // 全部转为大写 if(str[i]>='a'&&str[i]<='z'){ str[i] = str[i]-'a'+'A'; } /*//全部转小写 if (str[i]>='A'&&str[i]<='Z'){ str[i]=str[i]-'A'+'a'; } */ } printf("%s\n", str);}
在使用scanf和printf函数时要加上#include
。其中scanf()是格式输入函数,printf()函数是格式化输出函数。
其通常的用法如下:
#include
int main()
{
int i, j;
scanf("%d, %d", &i, &j);//从键盘输入i,j
printf("i=%d;j=%d", i, j);//输出i,j;
return 0;
}
C的scanf和printf连用?
改成如下的形式就是输入一个数立即打印,可见是scanf("%d\n",&a[i][j]);中\n在作怪。
#include
void main()
{
int a[2][3];
int i,j;
for(i=0;i<2;++i)
{
for(j=0;j<3;++j)
{
scanf("%d",&a[i][j]);
printf("a[%d][%d]\n",i,j);
}
}
printf("\n");
}
scanf("%d\n",&a[i][j]); 改成 scanf("%d",&a[i][j]);即format串中不要‘\n’ 号
4.1 格式输入与输出 4.1.1 printf函数(格式输出函数) printf函数称为格式输出函数,其关键字最末一个字母f即为“格式”(format)之意。其功能是按用户指定的格式,把指定的数据显示到显示器屏幕上。在前面的例题中我们已多次使用过这个函数。1. printf函数调用的一般形式printf函数是一个标准库函数,它的函数原型在头文件“stdio.h”中。但作为一个特例,不要求在使用 printf 函数之前必须包含stdio.h文件。printf函数调用的一般形式为: printf(“格式控制字符串”,输出表列)其中格式控制字符串用于指定输出格式。格式控制串可由格式字符串和非格式字符串两种组成。格式字符串是以%开头的字符串,在%后面跟有各种格式字符,以说明输出数据的类型、形式、长度、小数位数等。如:“%d”表示按十进制整型输出;“%ld”表示按十进制长整型输出;“%c”表示按字符型输出等。非格式字符串在输出时原样照印,在显示中起提示作用。输出表列中给出了各个输出项,要求格式字符串和各输出项在数量和类型上应该一一对应。【例4.3】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,b的值,但由于格式控制串不同,输出的结果也不相同。第四行的输出语句格式控制串中,两格式串%d 之间加了一个空格(非格式字符),所以输出的a,b值之间有一个空格。第五行的printf语句格式控制串中加入的是非格式字符逗号,因此输出的a,b值之间加了一个逗号。第六行的格式串要求按字符型输出 a,b值。第七行中为了提示输出结果又增加了非格式字符串。2. 格式字符串在Turbo C中格式字符串的一般形式为: [标志][输出最小宽度][.精度][长度]类型 其中方括号[]中的项为可选项。各项的意义介绍如下:1) 类型:类型字符用以表示输出数据的类型,其格式符和意义如下表所示:格式字符意 义d以十进制形式输出带符号整数(正数不输出符号)o以八进制形式输出无符号整数(不输出前缀0)x,X以十六进制形式输出无符号整数(不输出前缀Ox)u以十进制形式输出无符号整数f以小数形式输出单、双精度实数e,E以指数形式输出单、双精度实数g,G以%f或%e中较短的输出宽度输出单、双精度实数c输出单个字符s输出字符串2) 标志:标志字符为-、+、#、空格四种,其意义下表所示:标 志意 义-结果左对齐,右边填空格+输出符号(正号或负号)空格输出值为正时冠以空格,为负时冠以负号#对c,s,d,u类无影响;对o类,在输出时加前缀o;对x类,在输出时加前缀0x;对e,g,f 类当结果有小数时才给出小数点3) 输出最小宽度:用十进制整数来表示输出的最少位数。若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。4) 精度:精度格式符以“.”开头,后跟十进制整数。本项的意义是:如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。5.长度:长度格式符为h,l两种,h表示按短整型量输出,l表示按长整型量输出。【例4.4】main(){ int a=15; float b=123.1234567; double c=12345678.1234567; char d='p'; printf("a=%d,%5d,%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,%8c\n",d,d); } 本例第七行中以四种格式输出整型变量a的值,其中“%5d ”要求输出宽度为5,而a值为15只有两位故补三个空格。 第八行中以四种格式输出实型量b的值。其中“%f”和“%lf ”格式的输出相同,说明“l”符对“f”类型无影响。“%5.4lf”指定输出宽度为5,精度为4,由于实际长度超过5故应该按实际位数输出,小数位数超过4位部分被截去。第九行输出双精度实数,“%8.4lf ”由于指定精度为4位故截去了超过4位的部分。第十行输出字符量d,其中“%8c ”指定输出宽度为8故在输出字符p之前补加7个空格。使用printf函数时还要注意一个问题,那就是输出表列中的求值顺序。不同的编译系统不一定相同,可以从左到右,也可从右到左。Turbo C是按从右到左进行的。请看下面两个例子:【例4.5】main(){ int i=8; printf("%d\n%d\n%d\n%d\n%d\n%d\n",++i,--i,i++,i--,-i++,-i--);}【例4.6】main(){ int i=8; printf("%d\n",++i); printf("%d\n",--i); printf("%d\n",i++); printf("%d\n",i--);printf("%d\n",-i++); printf("%d\n",-i--);}这两个程序的区别是用一个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。但是必须注意,求值顺序虽是自右至左,但是输出顺序还是从左至右,因此得到的结果是上述输出结果。4.1.2 scanf函数(格式输入函数) scanf函数称为格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。1. scanf函数的一般形式scanf函数是一个标准库函数,它的函数原型在头文件“stdio.h”中,与printf函数相同,C语言也允许在使用scanf函数之前不必包含stdio.h文件。scanf函数的一般形式为: scanf(“格式控制字符串”,地址表列);其中,格式控制字符串的作用与printf函数相同,但不能显示非格式字符串,也就是不能显示提示字符串。地址表列中给出各变量的地址。地址是由地址运算符“&”后跟变量名组成的。例如:&a, &b分别表示变量a和变量b 的地址。这个地址就是编译系统在内存中给a,b变量分配的地址。在C语言中,使用了地址这个概念,这是与其它语言不同的。 应该把变量的值和变量的地址这两个不同的概念区别开来。变量的地址是C编译系统分配的,用户不必关心具体的地址是多少。变量的地址和变量值的关系如下:在赋值表达式中给变量赋值,如: a=567 则,a为变量名,567是变量的值,&a是变量a的地址。但在赋值号左边是变量名,不能写地址,而scanf函数在本质上也是给变量赋值,但要求写变量的地址,如&a。这两者在形式上是不同的。&是一个取地址运算符,&a是一个表达式,其功能是求变量的地址。【例4.7】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 92. 格式字符串格式字符串的一般形式为:%[*][输入数据宽度][长度]类型其中有方括号[]的项为任选项。各项的意义如下: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("%5d",&a);输入:12345678只把12345赋予变量a,其余部分被截去。又如: scanf("%4d%4d",&a,&b);输入:12345678将把1234赋予a,而把5678赋予b。4) 长度:长度格式符为l和h,l表示输入长整型数据(如%ld) 和双精度浮点数(如%lf)。h表示输入短整型数据。使用scanf函数还必须注意以下几点:1) scanf函数中没有精度控制,如:scanf("%5.2f",&a);是非法的。不能企图用此语句输入小数为2位的实数。2) scanf中要求给出变量地址,如给出变量名则会出错。如 scanf("%d",a);是非法的,应改为scnaf("%d",&a);才是合法的。3) 在输入多个数值数据时,若格式控制串中没有非格式字符作输入数据之间的间隔则可用空格,TAB或回车作间隔。C编译在碰到空格,TAB,回车或非法数据(如对“%d”输入“12A”时,A即为非法数据)时即认为该数据结束。4) 在输入字符数据时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。例如: 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.8】main(){ char a,b; printf("input character a,b\n"); scanf("%c%c",&a,&b); printf("%c%c\n",a,b);}由于scanf函数"%c%c"中没有空格,输入M N,结果输出只有M。而输入改为MN时则可输出MN两字符。【例4.9】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"之间有空格时,输入的数据之间可以有空格间隔。5) 如果格式控制串中有非格式字符则输入时也要输入该非格式字符。 例如: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=76) 如输入的数据与输出的类型不一致时,虽然编译能够通过,但结果将不正确。【例4.10】main(){ int a; printf("input a number\n"); scanf("%d",&a); printf("%ld",a);} 由于输入数据类型为整型,而输出语句的格式串中说明为长整型,因此输出结果和输入数据不符。如改动程序如下:【例4.11】main(){ long a; printf("input a long integer\n"); scanf("%ld",&a); printf("%ld",a);}运行结果为: input a long integer 12345678901234567890当输入数据改为长整型后,输入输出数据相等。【例4.12】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码和对应的大写字母。【例4.13】main(){ int a; long b; float f; double d; char c;printf("\nint:%d\nlong:%d\nfloat:%d\ndouble:%d\nchar:%d\n",sizeof(a),sizeof(b),sizeof(f),sizeof(d),sizeof(c));} 输出各种数据类型的字节长度。
printf中能加scanf吗
呵呵,你是不是把PRINTF写在SCANF前边了?而且还有回车符。
你试试我说的吧。
在你PRINTF和后边的SCANF中间再加一个scanf("%c",c);
明白没?把你之前PRINTF剩下的哪个回车符用我这个SCANF给吃掉,然后在接受你要的。
不是你程序无法运行,而是你输入字符后你的程序运行完了,没看到结果,想看到结果可以在程序的最后再加一个getchar();等待输入一个字符,输入完之后再退出
printf中不能加scanf
的
你可以把scanf先在前面表示
哪位大神可以解答,为什么我这样输就不行,为什么先是scanf再是printf而且还要分着写,
scanf是输入函数,printf是输出函数 ... 你不先输入数据怎么输出数据呢?
#include
void main()
{
int a[10];
int i,min;
for(i=0;i<=9;i++)
{
//printf("%d",a[i]);
scanf("%d",&a[i]); //scanf是格式输入函数,给每个数组元素对象赋值
//想输出数据,必须在scanf
}
min=a[0];
for(i=1;i<=9;i++)
if(min>a[i])
min=a[i];
printf("%d",min); //printf是格式输出函数, 这里是输出最小值
}
先写scanf函数是给数组中的元素赋值,然后再输出该值。如果你先输出,这时数组中的元素都还没有赋值呢,会输出一些不确定的数。
如何实现先printf在scanf
修改代码如下:
望采纳
#include
int main()
{
int i,j, h, f;
printf("请输入h(总头数)& f(总脚数)\n");
scanf("%d%d",&h,&f);
for(i=0;i<=h;i++)
if((4*i+(h-i)*2)==f)
printf("兔子有%d只,鸡有%d只",i,h-i);
return 0;
}
int x, y, h, f;
printf("请输入h(总头数)& f(总脚数)\n");
scanf("%d%d",&h,&f);
y=(f-2*h)/2;
x=h-y;
printf("鸡的数量=%d\n兔的数量=%d\n",x,y);
return 0;
在输出鸡兔数量前,scanf后的程序段中随便一个位置加一句
printf("输入数据为%d,%d",h,f);
就会有如下输出结果:
请输入h(总头数)& f(总脚数)
输入数据为16,40
鸡的数量=12
兔的数量=4
【C语言】gets和puts还有scanf和printf搭配使用
在程序中scanf和gets不能混合使用,如果一个程序中用scanf的话,一般不能再用gets,反之亦然,具体看下这个http://zhych16.blog.163.com/blog/static/113800992635217798/ 望采纳
#include
int main(){ char a[50]={0}; int l, h; printf("输入长和高:"); scanf("%d%d", &l, &h); printf("输入字符串a="); flushall();//清空缓冲区 gets(a); puts(a); return 0; }这样就可以了。
非格式化输入,字符和字符串的输入会受到前次输入缓冲区的影响,因此在gets、getchar等接收字符输入前,应该清空缓冲区。
printf和scanf可以用在C++里面吗?
在C语言中是用printf函数进行输出,用scanf函数进行输入的。C++保留了C语言的这一用法
scanf函数一般格式是:scanf(格式控制, 输出表列)printf函数的一般格式是printf(格式控制,输出表列)
例:用scanf和printf函数进行输入和输出
#include
using namespace std;int main( ){ int a; float b; char c; scanf("%d %c %f",&a,&c,&b); //注意在变量名前要加地址运算符& printf("a=%d,b=%f,c=%c\n",a,b,c); return 0;}
能,C++支持C,所以C所有的库函数都可以在C++中使用。
可以使用,相关代码如下:
#include
int main(){
int i;
scanf("%d",&i);
printf("%d",i);
return 0;
}
可以呀 不过要注意下格式 跟C语言格式不一样 SCAN就是C PLUS里面的语言
可以,添加头文件
可以。C++是C的超集,全面兼容C++。所以,printf和scanf在C里怎么用,在C++里就怎么用,语法一样。你可以上机试验一下。
C语言scanf和printf的使用问题
scanf语句scanf("%d,%d ",&a,&b);里面的%d之间不能用 , 号隔开
具体如下:
#include
void main()
{
int a,b;
printf("please enter four integer \n");
scanf("%d%d",&a,&b);
printf("%d\n,%d\n",a,b);
}
输入AB数据时中间用空格,如果想输出字符请用%C
scanf函数中定义%d%d之间不需要加逗号
#include
void main()
{
int a,b;
printf("please enter four integer \n");
scanf("%d,%d ",&a,&b);//""里面存在空格,要删去,同时输入时,两数字要用逗号隔开
printf("%d,%d",a,b);
getch();
}
c语言中,printf和scanf的用法?
printf就是输出的意思
第一句就是输出please
input
the
whole
number
of
people:
第二句就是输入,%d表示是整数,n为变量,
意思就是输入一个整数
scanf是实现从键盘输入的,而printf则是输出内容到显示器上
$curl = curl_init();
curl_setopt($curl,CURLOPT_URL,$_GET['url']);
curl_setopt($curl,CURLOPT_RETURNTRANSFER,true);
curl_setopt($curl,CURLOPT_USERAGENT,"Mozilla/4.0
(compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322; .NET CLR 2.0.50727)");
$output = curl_exec($curl);
curl_close($curl);
print_r($output);
scanf是C语言中的一个输入函数,与printf函数一样,都被声明在头文件stdio.h里,因此在使用scanf函数时要加上#include 。(在有一些实现中,printf函数与scanf函数在使用时可以不使用预编译命令#include 。)它是格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。scanf函数返回成功读入的数据项数,读入数据时遇到了“文件结束”则返回EOF。