我怀疑这可能有一些做,因为我用双打来控制循环终止舍入误差,但我想真正了解发生了什么事情while循环不会终止正确
#include<iostream>
using namespace std;
int main()
{
double h = 0.2; // stepsize
double t_0 = 1;
double t_n = 25;
double y_0 = 1; // initial condition
double t = t_0;
while(t < t_n)
{
cout << "t: " << t << endl;
cout << "(t < t_n): " << (t < t_n) << endl;
t += h;
}
}
输出的最后几行是
t: 24.4
(t < t_n): 1
t: 24.6
(t < t_n): 1
t: 24.8
(t < t_n): 1
t: 25
(t < t_n): 1
应该不是最后陈述返回false?也就是说,循环不应终止@ 24.8?
所以即使“25”被打印到屏幕上,它实际上是24.99内部的东西吗?另外,你会如何建议终止这样一个循环,知道你不能退出使用0.2?并且谢谢! – bcf 2013-04-28 21:30:41
@大卫正确,你得到的数字非常接近'25'(24.9 ...和大量的9),所以'printf'将它打印为'25'。 – dasblinkenlight 2013-04-28 21:38:03