2s函数c语言中 c语言2s%

c语音里面%.2s代表几个字节

%d 表示在相应的位置显示与之对应的整形变量值f 表示变量f的地址,大多在scanf时使用\n 表示换行%2d %md 以宽度m输出整型数,不足m时,左补空格

成都创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于成都做网站、成都网站制作、镇远网络推广、微信小程序、镇远网络营销、镇远企业策划、镇远品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联公司为所有大学生创业者提供镇远建站搭建服务,24小时服务热线:028-86922220,官方网址:www.cdcxhl.com

%f 表示在相应的位置显示与之对应的float变量值

c++中“scanf("%2d%*2s%2d", &x, &y);”是什么意思?

scanf("%2d%*2s%2d", x, y); 表示输入一个不大于两位数的整数存储到x中,再输入一个不超过2位的字符串(不赋值给任何变量),再输入一个不大于两位数的整数存储到y中!如:

输入 12aa34  x=12, y=34;

输入 1 + 2      x=1 , y=2;

附scanf()函数格式说明:

scanf函数是一个标准库函数,它的函数原型在头文件“stdio.h”中。

scanf函数的一般形式为:

scanf(“格式控制字符串”, 地址表列);

地址表列中给出各接收数据的变量的地址。

格式字符串的一般形式为:

%[*][输入数据宽度][长度符号]类型

其中有方括号[]的项为任选项。各项的意义如下:

类型  

表示输入数据的类型,如常用的d(整形) f(浮点型) c(字符) s(字符串)

“*”符

用以表示该输入项,读入后不赋予相应的变量,即跳过该输入值。

数据宽度

用十进制整数指定输入的宽度(即字符数)。

长度符号

长度格式符为l和h,l表示输入长整型数据(如%ld)和双精度浮点数(如%lf)。h表示输入短整型数据。

使用scanf函数还必须注意以下几点:

scanf函数中没有精度控制,如:scanf("%5.2f",a);是非法的。不能企图用此语句输入小数为2位的实数。

scanf中要求给出变量地址,如给出变量名则会出错。如 scanf("%d",a);是非法的,应改为scnaf("%d",a);才是合法的。

在输入多个数值数据时,若格式控制串中没有非格式字符作输入数据之间的间隔则可用空格,TAB或回车作间隔。C编译在碰到空格,TAB,回车或非法数据(如对“%d”输入“12A”时,A即为非法数据)时即认为该数据结束。

在输入字符数据时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。

c语言%2s中2如何换成变量,我想根据不同呢条件输出不同的长度

printf("%*s", x, str);

x的值会被替换到*的位置。

比如 x=10

那么就等效于%10s

c语言这题怎么回事,不是输入三个数吗? 题中的%2s是什么意思

不是%2s是 %*2s

带*的 表示忽略 也就是 读入一个整型x(2位) 然后忽略接下来的两个字符

再读取两个字符存到y中。

输入1234567的时候

前两位 x=12

中间两位 34被%*2s忽略

56两位 y=56

输出x+y=12+56=68

C语言中如何输出长整型数值

在C/C++中,64为整型一直是一种没有确定规范的数据类型。现今主流的编译器中,对64为整型的支持也是标准不一,形态各异。一般来说,64位整型的定义方式有long long和__int64两种(VC还支持_int64),而输出到标准输出方式有printf(“%lld”,a),printf(“%I64d”,a),和cout a三种方式。

本文讨论的是五种常用的C/C++编译器对64位整型的支持,这五种编译器分别是gcc(mingw32),g++(mingw32),gcc(linux i386),g++(linux i386),Microsoft Visual C++ 6.0。可惜的是,没有一种定义和输出方式组合,同时兼容这五种编译器。为彻底弄清不同编译器对64位整型,我写了程序对它们进行了评测,结果如下表。

上表中,正确指编译通过,运行完全正确;错误指编译虽然通过,但运行结果有误;无法编译指编译器根本不能编译完成。观察上表,我们可以发现以下几点:

long long定义方式可以用于gcc/g++,不受平台限制,但不能用于VC6.0。

__int64是Win32平台编译器64位长整型的定义方式,不能用于Linux。

“%lld”用于Linux i386平台编译器,”%I64d”用于Win32平台编译器。

cout只能用于C++编译,在VC6.0中,cout不支持64位长整型。

表中最后一行输出方式中的printint64()是我自己写的一个函数,可以看出,它的兼容性要好于其他所有的输出方式,它是一段这样的代码:

CPP

void printint64(long long a)

{

if (a=100000000)

printf("%d\n",a);

else

{

printf("%d",a/100000000);

printf("d\n",a0000000);

}

}

这种写法的本质是把较大的64位整型拆分为两个32位整型,然后依次输出,低位的部分要补0。看似很笨的写法,效果如何?我把它和cout输出方式做了比较,因为它和cout都是C++支持跨平台的。首先printint64()和cout(不清空缓冲区)的运行结果是完全相同的,不会出现错误。我的试验是分别用两者输出1000000个随机数,实际结果是,printint64()在1.5s内跑完了程序,而cout需要2s。cout要稍慢一些,所以在输出大量数据时,要尽量避免使用。

c语言的问题,解释下

#include stdio.h

main()

{

long int i,s,t,sum;//变量声明为长整形

t=300000;// 给t赋初值

s=1;// 给s赋初值

sum=1;// 给sum赋初值

for(i=2;i=30;i++)//循环30次(i从2到30)

{

s=2*s;//把2倍的s值赋给s

sum=sum+s;//求s与sum的和

}

sum=sum/100;//sum的值除100

printf("t=%ld\n",t);//打印t

printf("sum=%ld\n",sum);//打印sum

}

因为t的值在程序中没有改变,所以打印时还是原来的初值不变

sum的值是从1(sum=1)+2(s=1,s=1*2=2)+4(s=2*2=4)+8(s=4*2=8)+16(s=8*2=16)+……(30次)=1073741800

循环完了再/100=10737418

程序的功能就是求1,2,4,8,……(30个)的和


文章名称:2s函数c语言中 c语言2s%
文章来源:http://myzitong.com/article/dooiipd.html