1

这是我假设反转数组的方法。(另外,请记住,此方法可以接收锯齿状数组)

    public static int[][] reverse(int[][]a){

int[][] rev = new int[a.length][];

int row = a.length;

for(int x=0;x<a.length;x++){
   int col = a[x].length-1;
   for(int y=0; y< a[x].length;y++){

       rev[row-1][col-1]= a[x][y];
       col--;

       }
   row--;
   }

   return rev;


}// reverse method

我不断得到

Exception in thread "main" java.lang.NullPointerException
at Home.reverse(Home.java:259)
at Home.main(Home.java:56)

Java 结果:1

这是我调用该方法的主要内容

int[][] two = {{1,2,3,4},{0,1,2},{9},{1,3,5,7}};
System.out.println("The size of array os " + ar.length);
System.out.println("The columns of array is " + ar[0].length); 

int[][] rev;
//int[] b = concatenate(ar);
//int[] c = concatenate(two);
//int[][] rev = reverse(ar);

//for(int x=0;x<c.length;x++){System.out.println("worked" + c[x]);}

rev = reverse(two);

//for(int x = 0;x<rev.length;x++){
//  for(int y = 0;y<rev[x].length;y++){
//    System.out.print(rev[x][y]);
//}
//}
for(int x=0;x<rev.length;x++){
for(int y=0;y<rev[x].length;y++){
    System.out.print(rev[x][y]);
}
}

}// main

所以我的问题是真的,我哪里做错了?我追踪了我的反向方法,看起来它应该在做它的工作,但显然不是。

4

2 回答 2

3

您的数组rev尚未在其第二个坐标中初始化。在您声明之后int[][] rev = new int[a.length][],您的所有对象rev[i]都是null对象(数组是对象,即使对于原始类型也是如此)。为避免这种情况,如果数组是锯齿状的,请用int[][] rev = new int[a.length][a[0].length]或用或左右初始化。rev[i] = new int[a[i].length]

于 2013-03-22T21:51:49.013 回答
1

当你说这行

int[][] rev = new int[a.length][];

您已经创建了一个长度a.length为数组的数组,但内部数组都是null. NullPointerException所以你在这条线上得到了一个:

rev[row-1][col-1]= a[x][y];

您需要在第一个 for 循环中创建内部数组。这将满足您的“锯齿状阵列”要求。

for(int x=0;x<a.length;x++){
   int col = a[x].length-1;
   rev[row-1] = new int[a[x].length];  // Add this to create differing lengths.
   for(int y=0; y< a[x].length;y++){
于 2013-03-22T21:53:47.987 回答