扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
%d 表示在相应的位置显示与之对应的整形变量值f 表示变量f的地址,大多在scanf时使用\n 表示换行%2d %md 以宽度m输出整型数,不足m时,左补空格
成都创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于成都做网站、成都网站制作、镇远网络推广、微信小程序、镇远网络营销、镇远企业策划、镇远品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联公司为所有大学生创业者提供镇远建站搭建服务,24小时服务热线:028-86922220,官方网址:www.cdcxhl.com
%f 表示在相应的位置显示与之对应的float变量值
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即为非法数据)时即认为该数据结束。
在输入字符数据时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。
printf("%*s", x, str);
x的值会被替换到*的位置。
比如 x=10
那么就等效于%10s
不是%2s是 %*2s
带*的 表示忽略 也就是 读入一个整型x(2位) 然后忽略接下来的两个字符
再读取两个字符存到y中。
输入1234567的时候
前两位 x=12
中间两位 34被%*2s忽略
56两位 y=56
输出x+y=12+56=68
在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要稍慢一些,所以在输出大量数据时,要尽量避免使用。
#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个)的和
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流