首頁 > 軟體

java稀疏陣列的範例程式碼

2022-07-09 22:01:32

稀疏組織

  • 當一個陣列中大部分元素為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 

以上就是關於稀疏陣列的講解,有不理解的可以跟著程式碼試一下,然後自己建立一個陣列,並把陣列轉換為稀疏陣列!再試著轉換回來。

到此這篇關於java稀疏陣列的文章就介紹到這了,更多相關java稀疏陣列內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com