scanf d d n m("%d",&n); scanf d d n m("%lf",&a[i]);翻译成c++语言

scanf(&%d&,&bc); scanf(&%d&,&b【c语言吧】_百度贴吧
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&签到排名:今日本吧第个签到,本吧因你更精彩,明天继续来努力!
本吧签到人数:0成为超级会员,使用一键签到本月漏签0次!成为超级会员,赠送8张补签卡连续签到:天&&累计签到:天超级会员单次开通12个月以上,赠送连续签到卡3张
关注:567,890贴子:
scanf(&%d&,&bc); scanf(&%d&,&b收藏
scanf(&%d&,&bc); scanf(&%d&,&b
登录百度帐号推荐应用> 博客详情
相信不管大神还是菜鳥,都认得printf.它家还有兄弟sprintf,scanf,sscanf...$^&* 当你华丽丽的写下char c='c';printf("char=%d",c);的时候,一切都还是那么美好.
不过当你声明一个char buf[2];然后sscanf("30000","%d",buf);的时候,就不那么好玩了.
本以为2个字节足够装下32767以内的数字,却把内存写爆了.
此处关键就是格式符乱写产生的问题. 此时最想要的就是一份完整的可用格式表.
苦于每次都只能找到零星点点还不全,本来打算在此收集做一个全集,在收集过程中发现了一个完整版本转来
格式转换说明符printf() / scanf()
                  表一 转换说明符及作为结果的打印输出
浮点数、十六进制数字和p-记数法&(C99)
浮点数、十六进制数字和P-记数法&(C99)
有符号十进制整数
浮点数、e-记数法
浮点数、E-记数法
浮点数,十进制记数法
根据数值不同自动选择%f或者%e。%e格式在指数小于-4或者大于等于精度时使用
根据数值不同自动选择%f或者%E。%E格式在指数小于-4或者大于等于精度时使用
有符号十进制整数&(与%d相同)
无符号八进制整数
指针(就是指地址)
无符号十进制整数
使用十六进制数字0f&的无符号十六进制整数
使用十六进制数字0F的无符号十六进制整数
打印一个百分号
                  表二&printf()&修饰符
五种标志&(-、+、空格、#&和0)&都将在表三中描述,可以使用零个或多个标志
字段宽度的最小值。如果该字段不能容纳要打印的数或者字符串,系统会使用更宽的字段。示例:“%4d”
精度。对于%e、%E和%f转换,是将要在小数点的右边打印的数字的位数。对于%g和%G转换,是有效数字的最大位数。对于%s转换,是将要打印的字符的最大数目。对于整数转换,是将要打印的数字的最小位数;如果必要,要使用前导零来达到这个位数。只使用“.”表示其后跟随一个零,所以%.f与%.0f相同。示例:“%5.2f”打印一个浮点数,他的字段宽度为5个字符,小数点后有两个数字。
和整数转换说明符一起使用,表示一个short int&或者&unsigned short int&类型数值。
示例:“%hu”、“%hx”和“%6.4hd”
和整数转换说明符一起使用,表示一个signed char&或者unsigned char类型数值。
示例:“%hhu”、“%hhx”和“%6.4hhd”
和整数转换说明符一起使用,表示一个intmax_t或uintmax_t值。
示例:“%jd”和“%8jX”
和整数说明符一起使用,表示一个long int&或者unsigned long int&类型值。
示例:“%ld”和“%8lu”
和整数说明符一起使用,表示一个long long int或&unsigned long long int&类型值&(C99)。
示例:“%lld”和“%8llu”
和浮点转换说明符一起使用,表示一个long double值。
示例:“%Lf”和“%10.4Le”
和整数转换说明符一起使用,表示一个ptrdiff_t值(与两个指针之间的差相对应的类型) (C99)
示例:“%td”和“%12ti”
和整数转换说明符一起使用,表示一个size_t值(sizeof返回的类型) (C99)。
示例:“%zd”和“%12zx”
                  表三&printf()的标志
项目是左对齐的,也就是说,会把项目打印在字段的左侧开始处。示例:“%-20s”
有符号的值若为正,则显示带加号的符号;若为负,则带减号的符号。示例:“%+6.2f”
有符号的值若为正,则显示时带前导空格(但是不显示符号);若为负,则带减号符号。+标志会覆盖空格标志。示例:“% 6.2f”
使用转换说明的可选形式。若为%o格式,则以0开始;若为%x和%X格式,则以0x或0X开始,对于所有的浮点形式,#保证了即使不限任何数字,也打印一个小数点字符。对于%g和%G格式,它防止尾随零被删除。示例:“%#o”、“%#8.0f”和“%+#10.3E”
对于所有的数字格式,用前导零而不是用空格填充字段宽度。如果出现-标志或者指定了精度(对于整数)则忽略该标志。示例:“%010d”和“%08.3f”
                  表四&ANSIC&中&scanf()的转换说明符
转换说明符
把输入解释成一个字符
把输入解释成一个有符号十进制整数
%e,%f,%g,&%a
把输入解释成一个浮点数&(%a是C99标准)
%E,%F,%G,%A
把输入解释成一个浮点数&(%A是C99标准)
把输入解释成一个有符号十进制整数
把输入解释成一个有符号八进制数
把输入解释成一个指针(地址)
把输入解释成一个字符串;输入的内容以一个非空白字符作为开始,并且包含知道下一个空白字符的全部字符
把输入解释成一个无符号十进制整数
把输入解释成一个有符号十六进制整数
                  表五&scanf()的转换修饰符
滞后赋值。示例:“%*d”
最大字段宽度;在达到最大字段宽度或者遇到第一个空白字符时(不管哪一个先发生都一样)停止对输入项的读取。示例:“%10s”
把整数读作signed char&或&unsigned char&。示例:“%hhd”“%hhu”
把整数读作long long或者&unsigned long long (C99)。示例:“%lld”“%llu”
“%hd”和“hi”指示该值将会存储在一个short int中。
“%ho”“%hx”和“%hu”指示该值将会存储在一个unsigned short int中。
“%ld”和“%li”指示该值将会存储在一个long中。
“%lo”“%lx”和“%lu”指示该值将会存储在一个unsigned long中。
“%le”“%lf”和“%lg”指示该值以double类型存储。将L(而非l)与e、f和g一起使用指示该值以long double类型存储。
如果没有这些修饰符,d、i、o和x指示int类型,而e、f和g指示float类型。
                表附一 特别说明符
转换说明符
配合u,d等,可以输入输出64位整数.MSVC平台有效.如%I64u , %I64d. 注意大写
最后小结一下,一个字节的用%c,%hhu,%hhd等,两个字节用%hu,%hd等,四个字节用%d,%u等8个字节的用%lld,%llu等. 尽量不要用%I64d这样不兼容的格式.
秉承开源精神,以上内容欢迎纠正,补充!
尊重原创,尊重知识产权,从我做起. 本文引用:http://www.cnblogs.com/zxpgo/archive//2632169.html
支付宝支付
微信扫码支付
打赏金额: ¥
已支付成功
打赏金额: ¥当前位置:
&这简单的求值。。。为啥结果是这呢? 大神们看一下
这简单的求值。。。为啥结果是这呢? 大神们看一下
作者 三年不多
#include&stdio.h&
double a,b,c,d;
double x=0,y=0;
scanf(&%f,%f,%f,%f&,&a,&b,&c,&d);
x=(a-c)/(b-d);
y=(a*d-c*b)/(d-b);
printf(&x=%f,y=%f&,x,y);
QQ截图01.png
然而并没有看到图
%f 改为%lf 试试,因为你定义的变量都是double
1.scanf里一定要用%lf,因为你定义的是double
2.你输入的时候,那个逗号请使用半角逗号,全角会报错
#include &stdio.h&
double a,b,c,d;
double x,y;
scanf(&%lf,%lf,%lf,%lf&,&a,&b,&c,&d);
x=(a-c)/(b-d);
y=(a*d-c*b)/(d-b);
printf(&x=%f\ny=%f\n&,x,y);
return 0 ;
#注意输入a,b,c,d四个值的时候,值之间必须有逗号,并且不能添加空格等其他符号。
24小时热帖
下载小木虫APP
与700万科研达人随时交流

我要回帖

更多关于 scanf d n 1 的文章

 

随机推荐