数组元素的转置
关于数组的转置,其实就是将数组中的元素原本的排序,转换一下顺序重新排序,
也就是正序和倒序的转换。但转换过程并不是文字上的那么简单。
我想先介绍一下我的第一个实现方式:
我先创建了一个数组,将我测试的整数存入进去,
然后创建了第二个空数组,将空数组的长度设置为与第一个数组长度相等。
然后定义一个变量,其值为第一个数组的最后一个元素。
然后遍历第二个空数组,在这个遍历过程当中,将第一个数组的元素,逐个存入新数组当中,其中每个存储的元素为第一个数组的最后一个元素,此过程是一个动态过程,也就是让之前定义的变量做为第一个数组的下标,利用–自减操作,将其值逐个存储到新数组。
来看一下代码:
public class TestArrayTrs {
public static void main(String[] args) {
int array[] = {1,2,3,4,5,6,7,8,9};
int temp[] = new int[array.length];
int foot = array.length-1;
for (int i = 0; i < temp.length; i++) {
temp[i] = array[foot];
foot--;
}
array = temp;
print(array);
}
public static void print(int[] temp){
for (int i = 0; i < temp.length; i++) {
System.out.print(temp[i]+"\t");
}
}
}
其实这里存在一个问题
先描述一下代码的状态:
第一个数组是由静态初始化创建的,静态初始化的特点是在创建过程中,将其元素值就设置进去的,而他的长度是由系统分配的。
第二个数组是动态初始化创建的,他的内存空间是我们自己指定开辟的,在这里将第二个数组的空间大小设置为等同第一个数组的内存空间大小。
然后进行转置。
转置之后,调用自定义方法,这个方法和转置动作后的数组产生了引用传递,也就是方法当中的数组,内存空间指向的是第一个数组的内存空间。
存在的问题是:我第一次写这段代码,第二个数组的创建方式也是静态初始化的,虽然长度也设置等同第一个数组,但是我们知道,静态初始化的特点是由系统分配内存大小。所以本不该出现的ArrayIndexOutOfBoundsException也是可以理解的。