C语言中如果定义一个变量double k;那么下面是用printf或者scanf函数时使用%f还是%lf 那long double呢?

2024-11-20 16:39:57
推荐回答(5个)
回答1:

C语言中float , double , long double三种类型的输入输出格式是有差别的,如果不正确使用,则会造成数据输入或输出的不正常,导致程序运行错误。

各类型输入格式说明:

  1. float :

    float f1;

    输入:scanf("%f", &f1);

    输出:printf("%f", f1 );

  2. double:

    double d1;

    输入:scanf("%lf", &d1);

    输出:printf("%lf", d1 );  或 printf("%f", d1 ); 

  3. long double:

    long double ld1;

    输入:scanf("%lf", &ld1);

    输出:printf("%lf", ld1 );

回答2:

f 占4个字节,lf占8个字节,double也占8个字节,long double占16个字节,所以 double k用%lf, long double k的话用%llf。如果用%f,%lf的话会溢出。

回答3:

double 两个都能用
long double 只能用%lf

回答4:

一楼说法没错,long duoble只能用%lf

回答5:

%f %lf 为格式控制
字符串的一般形式: % [修饰符] 转换说明符
%f 为按浮点型小数输出
double 为双精度型数据 必须用%lf:用于双精度型数据的输出
这是在用scanf的时候要注意的,不然如果你:
double j;
scanf("%f",&j); 这个时候就会出现溢出.
而如果 j 是double型.并且j已经赋值过,这个时候可以用printf("%f",j);只是跟%lf这个格式输出的精度不一样罢了.
而long double其实呢,用%lf 够了吧。你要处理的数据需要多大呢? 这里%f %lf多用几次估计就知道怎么回事了