1、概念
具有想同类型的数据的有序集合。
2、使用
public class Test01 { public static void main(String[] args) { int a[]={7,1,9,10,5,4,8}; for (int i = 0; i < a.length-1; i++) { for (int j = 0; j < a.length - 1-i; j++) { int temp; if (a[j]>a[j+1]){ temp=a[j]; a[j]=a[j+1]; a[j+1]=temp; } } } for (int i1 = 0; i1 < a.length; i1++) { System.out.print(a[i1]+"\t"); } } }
3.Arrays类
常用方法:
-
fill():数组赋值
-
sort():升序排列
-
equals():比较数组元素值是否相等
-
binarySearch():对数组进行二分查找
4.稀疏数组
当一个数组中大部分元素为零,或者同一值的数组时,用稀疏数组保存该数组。
public class Test01 {
public static void main(String[] args) {
//创建二维数组, 0:无棋子 1:黑棋 2:白棋
int array1[][]=new int[11][11];
array1[1][2]=1;
array1[2][3]=2;
System.out.println("原始的数组:");
for (int[] ints : array1) {
for (int anInt : ints) {
System.out.print(anInt+"\t");
}
System.out.println();
}
//获取有效值个数
int sum=0;
for (int i = 0; i < array1.length; i++) {
for (int j = 0; j < array1.length; j++) {
if (array1[i][j]!=0){
sum++;
}
}
}
System.out.println("有效值个数:"+sum);
int [][] array2=new int[sum+1][3];
array2[0][0]=11;
array2[0][1]=11;
array2[0][2]=sum;
int count=0;
for (int i = 0; i < array1.length; i++) {
for (int j = 0; j < array1[i].length; j++) {
if (array1[i][j]!=0){
count++;
array2[count][0]=i;
array2[count][1]=j;
array2[count][2]=array1[i][j];
}
}
}
System.out.println("稀疏数组:");
for (int i = 0; i < array2.length; i++) {
System.out.println(array2[i][0]+"\t"
+array2[i][1]+"\t"
+array2[i][2]+"\t");
}
System.out.println("=========================");
System.out.println("还原");
int array3[][]=new int[array2[0][0]][array2[0][1]];
for (int i = 1; i < array2.length; i++) {
array3[array2[i][0]][array2[i][1]]=array2[i][2];
}
System.out.println("还原的数组:");
for (int[] ints : array3) {
for (int anInt : ints) {
System.out.print(anInt+"\t");
}
System.out.println();
}
}
}