数组反转也是Java的基础。
数组反转要求掌握的是:
1)、创建一个数组,在内存中申请一块空间。
2)、实例化数组。
3)、对数组的了解。如:数组的长度,数组的下标,数组的表示方法。
4)、数组的交换。
5)、数组的输出。
数组反转让我们更好的了解数组的下标,和循环语句。要清楚数组的下标变化和数值的交换位置。
我用两种方法写出数组的反转,如下代码:
/*
* 数组反转
*
* 方法1:
* a[i]与a[a.length-1-i]数值交换位置
* 要在(a.length-1)/2这里停止,不然没有反转了
*
* 方法2:
* 用 i=0 和 k=array.length-1 分别表示数组的第一位和最后一位
* 当i<k就交换两个数
* 再来就 i++ 而 k--
*/
package com.basis; public class ArrayReverse { //主方法
public static void main(String[] args) {
int[] array = {0,1,2,3,4,5,6,7,8,9};
System.out.print("原数组:");
printArray(array);
System.out.print("反转数组:");
arrayReverse1(array);
printArray(array);
System.out.print("再反转数组:");
arrayReverse2(array);
printArray(array);
} //方法1
public static int[] arrayReverse1(int array[]){
for(int i=0;i<(array.length-1)/2;i++){
int temp = array[i];
array[i] = array[array.length-1-i];
array[array.length-1-i] = temp;
}
return array;
} //方法2
public static int[] arrayReverse2(int array[]){
for(int i=0,k=array.length-1;i<k;i++,k--){
int temp = array[i];
array[i] = array[k];
array[k] = temp;
}
return array;
} //输出方法
public static void printArray(int array[]){
for(int i=0;i<array.length;i++){
System.out.print(array[i]+" ");
}
System.out.println();
}
}
运行的结果: