稀疏組織 當一個數組中大部分元素為0,或者為同一個值的數組時,可以用稀疏數組來保存該數組 稀疏數組,記錄一共有幾行幾列,有多少個不同值 把具有不同值的元素和行里了及值記錄在一個小規模的數組中,從而縮小程式的規模! 我們定義一下原始數組: 原始數組如下: 0 0 3 0 0 0 0 0 0 4 0 0 ...
稀疏組織
- 當一個數組中大部分元素為0,或者為同一個值的數組時,可以用稀疏數組來保存該數組
- 稀疏數組,記錄一共有幾行幾列,有多少個不同值
- 把具有不同值的元素和行里了及值記錄在一個小規模的數組中,從而縮小程式的規模!
我們定義一下原始數組:
原始數組如下:
0 0 3 0 0
0 0 0 0 4
0 0 0 5 0
0 0 6 0 0
0 0 0 0 0
可以看出,這個數組大部分都是0,我們可以把這個數組轉化為稀疏數組
稀疏數組第一行存放的分別是總行數,總列數和存放的數據總數
//因為數組的下標是從0開始的,所以可以看出,第一行的第三個數,用下標表示,實際上是數組[0][2]
5 5 4
0 2 3
1 4 4
2 3 5
3 2 6
下麵看一下如何實現這種稀疏數組,又是如何把稀疏數組還原成
代碼示例:
package com.ling.array;
public class ArrayDemo11 {
public static void main(String[] args) {
int[][] array=new int[5][5];
array[0][2]=3;
array[1][4]=4;
array[2][3]=5;
array[3][2]=6;
System.out.println("原始數組如下:");
for (int[] ints : array) {
for (int anInt : ints) {
System.out.print(anInt+" ");
}
System.out.println();
}
System.out.println("行"+"\t"+"列"+"\t"+"存放的數據"+"\t");
//稀疏數組第一行存放的分別是總行數,總列數和存放的數據總數
// System.out.println(5+"\t"+5+"\t"+4);
// System.out.println(1+"\t"+3+"\t"+3);
// System.out.println(2+"\t"+5+"\t"+4);
// System.out.println(3+"\t"+4+"\t"+5);
// System.out.println(4+"\t"+3+"\t"+6);
int sum=0;
for (int i = 0; i <5 ; i++) {
for (int j = 0; j <5 ; j++) {
if (array[i][j]!=0){
sum++;
}
}
}
int[][] arr2=new int[sum+1][3];
//這個二維數組的第一行是確定的
arr2[0][0]=5;
arr2[0][1]=5;
arr2[0][2]=sum;
int count=0;
for (int i = 0; i < array.length; i++) {
for (int j = 0; j < array[i].length; j++) {
if (array[i][j]!=0){
count++;
arr2[count][0]=i;
arr2[count][1]=j;
arr2[count][2]=array[i][j];
}
}
}
System.out.println("輸出稀疏數組");
for (int[] ints : arr2) {
for (int anInt : ints) {
System.out.print(anInt+" ");
}
System.out.println();
}
}
}
輸出:
輸出原始的數組
0 0 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 2 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
有效值的個數:2
輸出稀疏數組:
11 11 2
1 2 1
3 2 2
=========分========割==========線=============
我們也可以把稀疏數組進行一個還原
列印還原後的數組
0 0 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 2 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
以上就是關於稀疏數組的講解,有不理解的可以跟著代碼試一下,然後自己創建一個數組,並把數組轉換為稀疏數組!再試著轉換回來。