C语言中如果定义一个变量double k;那么下面是用printf或者scanf函数时使用%f还是%lf 那long double呢?
C语言中如果定义一个变量doublek;那么下面是用printf或者scanf函数时使用%f还是%lf那longdouble呢?...
C语言中如果定义一个变量double k;那么下面是用printf或者scanf函数时使用%f还是%lf
那long double呢? 展开
那long double呢? 展开
7个回答
展开全部
C语言中float , double , long double三种类型的输入输出格式是有差别的,如果不正确使用,则会造成数据输入或输出的不正常,导致程序运行错误。
各类型输入格式说明:
float :
float f1;
输入:scanf("%f", &f1);
输出:printf("%f", f1 );
double:
double d1;
输入:scanf("%lf", &d1);
输出:printf("%lf", d1 ); 或 printf("%f", d1 );
long double:
long double ld1;
输入:scanf("%lf", &ld1);
输出:printf("%lf", ld1 );
展开全部
f 占4个字节,lf占8个字节,double也占8个字节,long double占16个字节,所以 double k用%lf, long double k的话用%llf。如果用%f,%lf的话会溢出。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
double 两个都能用
long double 只能用%lf
long double 只能用%lf
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
一楼说法没错,long duoble只能用%lf
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
%f %lf 为格式控制
字符串的一般形式: % [修饰符] 转换说明符
%f 为按浮点型小数输出
double 为双精度型数据 必须用%lf:用于双精度型数据的输出
这是在用scanf的时候要注意的,不然如果你:
double j;
scanf("%f",&j); 这个时候就会出现溢出.
而如果 j 是double型.并且j已经赋值过,这个时候可以用printf("%f",j);只是跟%lf这个格式输出的精度不一样罢了.
而long double其实呢,用%lf 够了吧。你要处理的数据需要多大呢? 这里%f %lf多用几次估计就知道怎么回事了
字符串的一般形式: % [修饰符] 转换说明符
%f 为按浮点型小数输出
double 为双精度型数据 必须用%lf:用于双精度型数据的输出
这是在用scanf的时候要注意的,不然如果你:
double j;
scanf("%f",&j); 这个时候就会出现溢出.
而如果 j 是double型.并且j已经赋值过,这个时候可以用printf("%f",j);只是跟%lf这个格式输出的精度不一样罢了.
而long double其实呢,用%lf 够了吧。你要处理的数据需要多大呢? 这里%f %lf多用几次估计就知道怎么回事了
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询