c语言里%f跟%lf有什么区别?

如题所述

由于精度的原因,输出%lf和%f的数据不同,可能会造成错误。

主要有一下四点区别:

1、代表的数据类型不同

%f代表单精度浮点型数据(float),%lf代表双精度浮点型数据(double)。

2、有效数字位数不同

单精度浮点数有效数字保证6位,部分7位,双精度浮点数有效数字保证15位,部分16位。

3、所能表示数的范围不同

单精度浮点的表示范围:-3.40E+38 ~ +3.40E+38,双精度浮点的表示范围:-1.79E+308 ~ +1.79E+308

4、在程序中处理速度不同
一般来说,CPU处理单精度浮点数的速度比处理双精度浮点数快。

温馨提示:内容为网友见解,仅供参考
第1个回答  2019-09-13
有的,输入的时候,
%f
表示
float单浮点数,
%lf
双浮点数。
输出的时候没区别。都是%f.
第2个回答  2020-05-14
支持楼上!
%f是单精度
float
%lf是双精度
doeble

c语言中f和lf的区别
在c语言中f和lf的全称是%lf 与%f,它们的区别如下:1、所能表示数的范围不同。单精度浮点的表示范围:-3.40E+38 ~ +3.40E+38,双精度浮点的表示范围:-1.79E+308 ~ +1.79E+308 2、有效数字位数不同。单精度浮点数有效数字保证6位,部分7位,双精度浮点数有效数字保证15位,部分16位。

C语言问题%f和%lf的区别
C语言中的%f和%lf是用于输出浮点数的格式控制符,它们在精度和性能上存在一些关键差异。类型区分:%f适用于单精度浮点型数据(float),而%lf则对应于双精度浮点型数据(double)。精度差异:单精度浮点数的有效数字位数通常为6位,但可能最多可达7位,而双精度浮点数的精度更优,至少15位,甚至16位。

c语言里%f跟%lf有什么区别?
1、代表的数据类型不同 f代表单精度浮点型数据(float),%lf代表双精度浮点型数据(double)。2、有效数字位数不同 单精度浮点数有效数字保证6位,部分7位,双精度浮点数有效数字保证15位,部分16位。3、所能表示数的范围不同 单精度浮点的表示范围:-3.40E+38 ~ +3.40E+38,双精度浮点的表示...

% f和% Lf有什么区别吗?
1、%f 是输出 float 型变量;%f 是输出 double 型变量;%Lf 是输出 long double 型变量。2、在C语言中,对于数值类型只有通过printf类函数输出这一种方式,比如printf, sprintf, fprintf等。这类函数输出时要求有格式符号,其中long double的格式符号为%Lf。以下是一个简单的参考代码,输出到标准输出...

c语言中的% f和% lf有什么区别?
f 是输出 double 型变量;区分:%f 是输出 float 型变量;%Lf 是输出 long double 型变量。基本数据类型 void:声明函数无返回值或无参数,声明无类型指针,显示丢弃运算结果。(C89标准新增)char:字符型类型数据,属于整型数据的一种。(K&R时期引入)int:整型数据,表示范围通常为编译器指定的内存...

C语言中 %f 与%lf 有什么区别?能否举一个简单易懂的例子?初学者,在线...
f 般对应单精度类型 float lf 般对应双精度类型 double f是单精度浮点型,输出的时候要满足6位小数。lf就是输出数值总长度为L,整数个数加小数个数,不足补空,右顶格起

利用scanf时什么时候用%f和%lf
f就是float,lf就是long float,所以当你要输入float类型的数值时就用%f,当你要输入double类型数值时就用%lf

c语言中%f与%lf有什么区别?
最简单的区别:f 一般对应单精度类型 float lf 一般对应双精度类型 double。

c语言编程中%lf和%f,有啥区别,什么double,长短型,求大神解释
%lf是双精度,8字节;%f是单精度,4字节;——也就是%lf对应double型就是,%f对应float型变量,用错了运行结果就出错。double的长型是10字节,精确到19位,double型是8字节,精确到16位,未见过“短double”型。但好多编译器下写long double仍是8字节,就是说没有区分长型和普通型……供参考。

C语言里scanf中,%lf和%f区别是什么?我这么写的。 double a; scanf...
f 是浮点型(单精度),占4字节 lf 是浮点型(双精度),占8字节 scanf 按格式化字符串指定类型将用户输入的内容转换,然后写到指定的地址。两种类型存储方式,所占内存不同,类型错误自然会得到错误结果。

相似回答