今天在计算数据的时候,我用c++算数的时候出现了点问题,如下图,就是double 类型的d取值为1,然后N为整型20,densityC为宏定义的0.5,结果算出来1.0*20*0.5得出数值为9???这计算机不拿我当人呢,请问大佬们这个怎么解决
正常,浮点计算有误差,强制转换成int是抹去小数,而不是四舍五入,可以让结果加上0.5,再转换为int