我有一个代码如下:
double a = 50e-12; double b = 50.5e-12; double c = b - a; std::cout<<"value of a,b and c is : "<现在我的输出是:a,b和c的值是:0.0000000001 0.0000000001 0.0000000000
我可以看到我的操作数已经四舍五入,因此我得到一个0作为输出,虽然我期望0.5.
有人可以帮我弄这个吗.?
1> Jerry Coffin..:在这种情况下,在我看来,使用(C++的近似)科学记数法打印结果是最有意义的:
#include#include int main() { double a = 50e-12; double b = 50.5e-12; double c = b - a; std::cout << std::scientific << c << "\n"; } 这产生了你所期望的:
5.000000e-13虽然您当然可以打印出十进制的所有13或15位数(或其他),但当您的输入采用(伪)科学记数法时,以相同的方式打印输出可能最有意义.