为什么结果为1.000000
本帖最后由 suchenxiang 于 2022-1-25 22:06 编辑#include <stdio.h>
int main()
{
float r;
r=5/3;
printf("%.6f\n",r);
return 0;
} 5和3都是整型,整型之间相除会取整
改成5.0/3 或者 5/3.0 因为 r = 5 / 3 底层执行逻辑是 先计算再强转为float
但如果是 5.0/3 或者 5/3.0,那么会在计算的时候 自动转为容量大的浮点型
整型,字符型,浮点型的数据在混合运算时,会自动转为容量大的类型
顺序:byte、short、char-> int -> long -> float -> double
因为这里您写的 printf("%.6f\n",r) 里的 "%.6" 设置了它无论如何都会把小数点精确到后六位! 楼上正解 罗巴乔 发表于 2022-1-26 09:39
楼上正解
谢谢兄弟支持!(其实我还没学 c ,是靠 Python 的格式化基础来看的...{:10_282:}) 5和3都是整型,结果也应为整型,但是你用浮点型接收,计算后的结果会被转换为浮点型,你定义int r,就是1了
如果你问的是为什么舍去了小数位的值的话,那是因为/在整数之间是取整运算,它只会保留整数部分的值,而5除以3的整数部分就是1,小数部分自然被舍去了,如果要精确到小数点后把5改成5.0或者把3改成3.0就可以了,只要有一个是浮点型或者double型就会保留小数
5和3都是整型,只要把其中之一改为”.0“的形式(如3.0,5.0)就可以
页:
[1]