0

私は次ArrayIndexOutOfBoundsExceptionのように言っています winVals[i] = randが、理由はわかりません。

int valueCount = 5;
int theLimit = 5;
int[] winVals = new int[valueCount];
Random r = new Random();
int rand = 0;
for(int i= 0; i < winVals.length; i++)
{
    rand = r.nextInt(theLimit - 1) +1;
    if(i == 0)
    {
        winVals[0] = rand;
    }
    else if (i > 0)
    {
        for (int j = 0; j < winVals.length; j++)
        { 
           if( winVals[j] == rand)
           {
              i--;
           }      
           else
           {
               winVals[i] = rand;
           }
        }
    }
}
for(int i=0; i < valueCount; i++)
{
    System.out.println(winVals[i]);
}
4

4 に答える 4

6
for (int j = 0; j < winVals.length; j++)
{ 
   if( winVals[j] == rand)
       i--;
   else
   {
       winVals[i] = rand;
   }
}

このセクションでは、の値をループしてj減少させていますが、それでも有効iかどうかを確認する必要はありません。i1で、2回減らすとどうiなりますか?

于 2012-10-10T21:03:31.590 に答える
1

ループ内のループカウンターをデクリメントします。

if( winVals[j] == rand)
     i--;

これは範囲外につながります。

于 2012-10-10T21:03:21.167 に答える
0

この線が問題だと思います。

   if( winVals[j] == rand)
     i--;

この行の前で、i=0およびj=0であり、この条件が真になると、iは-1になると考えてください。

于 2012-10-10T21:05:40.560 に答える
0

インデックスがデクリメントされる上記の理由により、これは無限ループで実行されます。

于 2012-10-10T21:11:11.900 に答える