suchenxiang 发表于 2022-1-25 22:05:21

为什么结果为1.000000

本帖最后由 suchenxiang 于 2022-1-25 22:06 编辑

#include <stdio.h>

int main()
{
        float r;
       
        r=5/3;
       
        printf("%.6f\n",r);
        return 0;
}

大马强 发表于 2022-1-25 22:14:15

5和3都是整型,整型之间相除会取整
改成5.0/3 或者 5/3.0

翼是孤独 发表于 2022-1-25 22:36:25

因为 r = 5 / 3 底层执行逻辑是 先计算再强转为float

但如果是 5.0/3 或者 5/3.0,那么会在计算的时候 自动转为容量大的浮点型
整型,字符型,浮点型的数据在混合运算时,会自动转为容量大的类型
顺序:byte、short、char-> int -> long -> float -> double

python爱好者. 发表于 2022-1-26 08:49:32

因为这里您写的 printf("%.6f\n",r) 里的 "%.6" 设置了它无论如何都会把小数点精确到后六位!

罗巴乔 发表于 2022-1-26 09:39:52

楼上正解

python爱好者. 发表于 2022-1-26 11:31:07

罗巴乔 发表于 2022-1-26 09:39
楼上正解

谢谢兄弟支持!(其实我还没学 c ,是靠 Python 的格式化基础来看的...{:10_282:})

YSW9527 发表于 2022-1-26 22:38:33

5和3都是整型,结果也应为整型,但是你用浮点型接收,计算后的结果会被转换为浮点型,你定义int r,就是1了
如果你问的是为什么舍去了小数位的值的话,那是因为/在整数之间是取整运算,它只会保留整数部分的值,而5除以3的整数部分就是1,小数部分自然被舍去了,如果要精确到小数点后把5改成5.0或者把3改成3.0就可以了,只要有一个是浮点型或者double型就会保留小数

ckg16 发表于 2022-1-29 10:28:06

5和3都是整型,只要把其中之一改为”.0“的形式(如3.0,5.0)就可以
页: [1]
查看完整版本: 为什么结果为1.000000