ばかげている場合は申し訳ありませんが、答えを見つけることができませんでした。
#include <iostream>
using namespace std;
int main()
{
double a(0);
double b(0.001);
cout << a - 0.0 << endl;
for (;a<1.0;a+=b);
cout << a - 1.0 << endl;
for (;a<10.0;a+=b);
cout << a - 10.0 << endl;
cout << a - 10.0-b << endl;
return 0;
}
出力:
0
6.66134e-16
0.001
-1.03583e-13
MSVC9、MSVC10、Borland C ++ 2010でコンパイルしてみました。それらはすべて、最終的に約1e-13のエラーで到着します。1000、10000の増分だけで、このような重大なエラーが蓄積されるのは正常ですか?