可能重复:
为什么 Visual Studio 2008 告诉我 .9 - .8999999999999995 = 0.00000000000000055511151231257827?
为什么像 1.82 这样的简单双打最终会变成 1.819999999645634565360?
当我编译并运行以下程序时,我得到了一个非常奇怪的行为:
#include <iostream>
#define DIV 10000ll
long long gcd(long long a, long long b) {
if(b==0) return a;
else return gcd(b, a % b);
}
int main() {
int t;
std::cin >> t;
while(t--) {
double n1;
std::cin >> n1;
long long inum=(long long)(n1*DIV);
std::cout << inum << std::endl;
if(inum==0) { std::cout << 1 << std::endl; }
else std::cout << DIV/gcd(inum,DIV) << std::endl;
}
return 0;
}
当我作为输入输入时:
1
0.0006
我得到输出
5
2000
这意味着:(long long)0.0006*10000
等于 5 而不是 6。为什么会这样?