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 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多用几次估计就知道怎么回事了