Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/cplusplus/134.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C++ 索引运行时间间隔错误_C++_Indexing - Fatal编程技术网

C++ 索引运行时间间隔错误

C++ 索引运行时间间隔错误,c++,indexing,C++,Indexing,我不明白为什么会这样。ngrid将是10的倍数。对于ngrid=10,比如说,当我打印出0.7*ngrid时,我得到7,这当然是正确的。但当我打印出来的时候,它会打印出6,以及7和8。为什么会这样?提前谢谢 for(int i=(0.7*ngrid); i<0.8*ngrid; i++) { cout << i; operator()(0.2*ngrid,i) = -3.0; } for(int i=(0.7*ngrid);i不混合整数

我不明白为什么会这样。ngrid将是10的倍数。对于ngrid=10,比如说,当我打印出0.7*ngrid时,我得到7,这当然是正确的。但当我打印出来的时候,它会打印出6,以及7和8。为什么会这样?提前谢谢

    for(int i=(0.7*ngrid); i<0.8*ngrid; i++)
    {
    cout << i;
    operator()(0.2*ngrid,i) = -3.0;
    }

for(int i=(0.7*ngrid);i不混合整数和浮点数/双精度。
for
仅用于数组索引或其他整数walktrru。请使用
while

或者,使用fixpoint,将所有值乘以100


编辑:当程序员在代码中为
找到一个
时,他们会认为,“这是对索引或整数坐标的一种演练”。如果你有这样的问题,比如当x*0.7达到某个级别时,循环中断,最好在
时使用
,这意味着“我们在重复某些东西,直到某种情况发生。”。某些语言甚至不允许在
for

中使用非整数。
for
仅用于数组索引或其他整数walktrru。请在
时使用

或者,使用fixpoint,将所有值乘以100


编辑:当程序员在代码中为
找到一个
时,他们会认为,“这是对索引或整数坐标的一种演练”。如果你有这样的问题,比如当x*0.7达到某个级别时,循环中断,最好在
时使用
,这意味着“我们在重复某些东西,直到某种情况发生。”。某些语言甚至不允许在
for

中使用非整数。
for
仅用于数组索引或其他整数walktrru。请在
时使用

或者,使用fixpoint,将所有值乘以100


编辑:当程序员在代码中为
找到一个
时,他们会认为,“这是对索引或整数坐标的一种演练”。如果你有这样的问题,比如当x*0.7达到某个级别时,循环中断,最好在
时使用
,这意味着“我们在重复某些东西,直到某种情况发生。”。某些语言甚至不允许在
for

中使用非整数。
for
仅用于数组索引或其他整数walktrru。请在
时使用

或者,使用fixpoint,将所有值乘以100


编辑:当程序员在代码中为
找到一个
时,他们会认为,“这是对索引或整数坐标的一种演练”。如果你有这样的问题,比如当x*0.7达到某个级别时,循环中断,最好在
时使用
,这意味着“我们在重复某些东西,直到某种情况发生。”。有些语言甚至不允许在
中为
使用非整数。您在这里做了一些危险的事情。首先,期望浮点运算的结果是一个精确的整数。事实证明,即使
ngrid
类型为
int
,0.7也不能用IEEE浮点格式表示。您可以n看看你是否用0.7表示为0.69999988079071。乘以10,然后将其转换为
int
,现在你有了6

类似地,0.8表示为0.8000001190929。因此,当8与8.00000011920929进行比较时,正确地确定为更小,因此也打印了8

因此,当你的
for
循环开始执行时,
i
被初始化为6而不是7。这就是为什么6会被打印出来。故事的寓意是,不要期望浮点运算能很好地变成整数……即使你只处理一个小数位。计算机不能处理以10为基数的数字,所以永远也不能一切都很容易表现出来


而不是进行浮点运算(假设
ngrid
int
),将其乘以7,然后除以7。这将执行整数运算,而不是浮点运算。因为您说过,
ngrid
始终是10的倍数,所以结果应该始终是整数,您不必担心截断。

您在这里做了一些危险的事情。首先,期待f的结果loat运算得出一个精确的整数。结果表明,即使
ngrid
类型为
int
,0.7也不能用IEEE浮点格式表示。您可以看到,如果使用该值,0.7实际上表示为0.69999988079071。乘以10,然后将其转换为
int
,现在您有了6

类似地,0.8表示为0.8000001190929。因此,当8与8.00000011920929进行比较时,正确地确定为更小,因此也打印了8

因此,当你的
for
循环开始执行时,
i
被初始化为6而不是7。这就是为什么6会被打印出来。故事的寓意是,不要期望浮点运算能很好地变成整数……即使你只处理一个小数位。计算机不能处理以10为基数的数字,所以永远也不能一切都很容易表现出来


而不是进行浮点运算(假设
ngrid
int
),将其乘以7,然后除以7。这将执行整数运算,而不是浮点运算。因为您说过,
ngrid
始终是10的倍数,所以结果应该始终是整数,您不必担心截断。

您在这里做了一些危险的事情。首先,期待f的结果loat运算得出一个精确的整数。结果表明,即使
ngrid
类型为
int
,0.7也不能用IEEE浮点格式表示。您可以看到,如果使用该值,0.7实际上表示为0.69999988079071。乘以10,然后将其转换为
int
,现在您有了6

类似地,0.8表示为0。
class Field
{
  private:
    double* data;
    int     n;
    int index(int x, int y) const { return x + (n+1)*y; }
  public:


    Field(int ngrid)  : n(ngrid)
    {
      data = new double[(ngrid+1)*(ngrid+1)];
      int l=(ngrid+1)*(ngrid+1);
      for (int i=0;i<l;i++) data[i]=0.0;
    }