-1

我正在尝试设计一个程序,如果它不是 0,则将数组中的值 0 与前面的元素交换。

例如,如果数组是,1 1 0 1 1 1那么程序将继续交换,直到它变成0 1 1 1 1 1

但是当我运行时会发生这种IndexOutOfBoundException情况。我什至尝试将 for 循环更改为:

for(int i = 1; i < newLane.length; i++)

这解决了越界问题,但使其功能不正确。

以下是我的代码:

public static int[] down(int[] lane) {   
    int lan = lane.length; // length of array
    int[]newLane = new int[lan];  // creates new 1d matrix

    for(int i = 1; i < newLane.length; i++) {  
        if(newLane[i-1] != 0 && newLane[i] == 0 ){ // getting out of bounds error
            int tmp = newLane[i - 1];
            newLane[i - 1] = newLane[i];
            newLane[i] = tmp;
        }
    }

    return newLane;
}
4

4 回答 4

1

我认为您可以简单地对数组进行排序:

public static int[] down(int[] lane){       
    int lan = lane.length; // length of array
    int[]newLane = Arrays.copyOf(lane,lan)  // creates new 1d matrix
    Arrays.sort(newLane);
    return newLane;
}
于 2012-09-30T07:11:34.860 回答
0

您无处使用 array 的元素Lane。当前newLane是一个空数组。我已将值分配LanenewLane

将您的功能更改为以下

public static int[] down(int[] lane){   

    int lan = lane.length; // length of array
    int[]newLane = new int[lan];  // creates new 1d matrix
    newLane = lane;

     for(int i = 1; i < newLane.length; i++) {  

         if(newLane[i-1] != 0 && newLane[i] == 0 ){ // getting out of bounds error
            int tmp = newLane[i - 1];
            newLane[i - 1] = newLane[i];
            newLane[i] = tmp;
            }



    }

         if(newLane[0]!=0 && newLane[1]==0)
         {
             int tmp = newLane[0];
                newLane[0] = newLane[1];
                newLane[1] = tmp;
         }
     return newLane;
    }

更新 在 for 循环之后,检查第 0 个元素是否非零。如果是,则先与它交换。

if(newLane[0]!=0 && newLane[1]==0)
         {
             int tmp = newLane[0];
                newLane[0] = newLane[1];
                newLane[1] = tmp;
         }
于 2012-09-30T07:05:32.073 回答
0

正如我的评论已经说过的那样:你很接近。
只需添加

if(newLane[0] == 0) newLane[0] == 1;

在for循环之前。

于 2012-09-30T07:07:25.143 回答
-1

我会试试这个

 public static int[]  swapping(int[] lane) 
  {   
int[] result = new int[lane.length];  

 for(int i = 0; i < result .length; i++) {  
      if ( result[i]==0) 
      {
        if( i==0)
           {
           }
         else
            {
       temp = result[i] ; 
       result[i]  = result [i-1] ; 
       result [i-1] = temp ; 
             }
     else
      {
       }
 return result ;
}
于 2012-09-30T07:15:49.883 回答