欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java二維數(shù)組與稀疏數(shù)組相互轉(zhuǎn)換實現(xiàn)詳解

 更新時間:2022年09月26日 08:37:31   作者:小黎的培培筆錄  
在某些應(yīng)用場景中需要大量的二維數(shù)組來進(jìn)行數(shù)據(jù)存儲,但是二維數(shù)組中卻有著大量的無用的位置占據(jù)著內(nèi)存空間,稀疏數(shù)組就是為了優(yōu)化二維數(shù)組,節(jié)省內(nèi)存空間

一、稀疏數(shù)組

1、什么是稀疏數(shù)組

當(dāng)一個數(shù)組中大部分元素為0,或者為同一個值的數(shù)組時,可以用稀疏數(shù)組來保存該數(shù)組。稀疏數(shù)組,記錄一共有幾行幾列,有多少個不為零的值或相同的值。

簡單來說就是將大規(guī)模的數(shù)組縮小成小規(guī)模的數(shù)據(jù),從而減少空間浪費。

2、圖示

上面的圖示中,左側(cè)是二維數(shù)組,右側(cè)是稀疏數(shù)組,將二維數(shù)組轉(zhuǎn)成稀疏數(shù)組,明顯的可以看出空間減少了,可以有效的節(jié)約空間,提高效率。那么二維數(shù)組怎么生成稀疏數(shù)組呢?其實很簡單,因為二維數(shù)組有特定的格式,按格式將二維數(shù)組中的數(shù)據(jù)放入稀疏數(shù)組即可。

3、稀疏數(shù)組的表達(dá)方式

稀疏數(shù)組的列是固定的,只有三列,第一列表示二維數(shù)組的行,第二列表示二維數(shù)組的列,第三列表示二維數(shù)組非零數(shù)的個數(shù)。稀疏數(shù)組的第一行是固定的,用來表示總行數(shù),總列數(shù),總個數(shù)。其余行數(shù)根據(jù)個數(shù)而定。

二、二維數(shù)組→稀疏數(shù)組

根據(jù)上圖所示:

第一步:創(chuàng)建二維數(shù)組

//首先創(chuàng)建二維數(shù)組
int[][] ChessArr1 = new int[11][11];
//賦值
ChessArr1[1][2] = 1;
ChessArr1[2][3] = 2;
//循環(huán)遍歷得到非零個數(shù)
int num = 0;
for(int[] row : ChessArr1) {
   for(int data : row) {
       if(data != 0) {
           num++;
        }
   }
}

上面用到了增強(qiáng)for循環(huán),第一個增強(qiáng)for循環(huán)表示每一個row代表一行(二維數(shù)組的行)也就相當(dāng)與一維數(shù)組,第二個增強(qiáng)for循環(huán)再遍歷一維數(shù)組得到每一個數(shù)據(jù)data來進(jìn)行判斷是否是非零數(shù)。

第二步:創(chuàng)建稀疏數(shù)組,并賦值

int[][] SparseArr = new int[num + 1][3];
//第一行賦值
SparseArr[0][0] = 11;
SparseArr[0][1] = 11;
SparseArr[0][2] = num;

前面分析的時候說了,第一行是固定的,二維數(shù)組的大小是知道的,所以行列的總數(shù)可以直接賦值,總有效個數(shù)也求了,也可以直接賦值。

第三步:遍歷二維數(shù)組并賦值給稀疏數(shù)組

        int count = 0;
        for(int i = 0; i < 11; i++) {
            for(int j = 0; j < 11; j++) {
                if(ChessArr1[i][j] != 0) {
                    count++;
                    SparseArr[count][0] = i;
                    SparseArr[count][1] = j;
                    SparseArr[count][2] = ChessArr1[i][j];
                }
            }
        }

遍歷二維數(shù)組,判斷條件是這個數(shù)不等于零,此處需要一個計數(shù)變量,每符合一個非零數(shù),計數(shù)變量就加一,可以用來表示稀疏數(shù)組的第幾行,稀疏數(shù)組的列數(shù)是固定的,所以找到后直接進(jìn)行賦值操作。

最后打印稀疏數(shù)組即可。

完整代碼

        //首先創(chuàng)建二維數(shù)組
        int[][] ChessArr1 = new int[11][11];
        //賦值
        ChessArr1[1][2] = 1;
        ChessArr1[2][3] = 2;
        //將原始數(shù)組轉(zhuǎn) 換成 稀疏數(shù)組
        //1、先遍歷原始數(shù)組得到非0數(shù)的個數(shù)
        int num = 0;
        for(int[] row : ChessArr1) {
            for(int data : row) {
                if(data != 0) {
                    num++;
                }
            }
        }
        //2、創(chuàng)建 稀疏數(shù)組
        int[][] SparseArr = new int[num + 1][3];
        //3、第一行賦值
        SparseArr[0][0] = 11;
        SparseArr[0][1] = 11;
        SparseArr[0][2] = num;
        //4、循環(huán)賦非0值
        int count = 0;
        for(int i = 0; i < 11; i++) {
            for(int j = 0; j < 11; j++) {
                if(ChessArr1[i][j] != 0) {
                    count++;
                    SparseArr[count][0] = i;
                    SparseArr[count][1] = j;
                    SparseArr[count][2] = ChessArr1[i][j];
                }
            }
        }
        //5、打印稀疏數(shù)組
        System.out.println("\n===打印稀疏數(shù)組===");
        for(int[] row : SparseArr) {
            for(int data : row) {
                System.out.printf("%d\t",data);
            }
            System.out.println();
        }

三、稀疏數(shù)組→二維數(shù)組

第一步:創(chuàng)建新的二維數(shù)組

//1、定義一個新的二維數(shù)組
int[][] ChessArr2 = new int[SparseArr[0][0]][SparseArr[0][1]];

二維數(shù)組的大小來自稀疏數(shù)組的第一行第一列和第一行第二列,也就是 SparseArr[0][0] 和 SparseArr[0][1] ;初始狀態(tài)下的二維數(shù)組數(shù)據(jù)全為零。

第二步:循環(huán)遍歷并賦值

        //2、賦值
        for(int i = 1; i <= SparseArr[0][2]; i++) {
            ChessArr2[SparseArr[i][0]][SparseArr[i][1]] = SparseArr[i][2];
        }

因為除了少數(shù)是有效個數(shù),其他全是零,所以我們只需要遍歷有效個數(shù)。i 表示第幾個有效個數(shù)也表示當(dāng)前這個數(shù)在稀疏數(shù)組中的行,如上圖所示:如 i = 1,表示在稀疏數(shù)組的第一行,它在二維數(shù)組中的位置為 (1,2),數(shù)值為 1 ;所以行和列分別是SparseArr[1][0]和SparseArr[1][1],數(shù)值為SparseArr[1][2]。

所以賦值表達(dá)式為:ChessArr2[SparseArr[i][0]][SparseArr[i][1]] = SparseArr[i][2]。

完整代碼

        //將稀疏數(shù)組 轉(zhuǎn)換成 二維數(shù)組
        //1、定義一個新的二維數(shù)組
        int[][] ChessArr2 = new int[SparseArr[0][0]][SparseArr[0][1]];
        //2、賦值
        for(int i = 1; i <= SparseArr[0][2]; i++) {
            ChessArr2[SparseArr[i][0]][SparseArr[i][1]] = SparseArr[i][2];
        }
        //3、打印新的二維數(shù)組
        System.out.println("\n===新的二維數(shù)組===");
        for(int[] row : ChessArr2) {
            for(int data : row) {
                System.out.printf("%d\t",data);
            }
            System.out.println();
        }

到此這篇關(guān)于Java二維數(shù)組與稀疏數(shù)組相互轉(zhuǎn)換實現(xiàn)詳解的文章就介紹到這了,更多相關(guān)Java二維數(shù)組與稀疏數(shù)組轉(zhuǎn)換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot項目從搭建到發(fā)布一條龍

    SpringBoot項目從搭建到發(fā)布一條龍

    這篇文章主要介紹了SpringBoot項目從搭建到發(fā)布一條龍,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • SpringBoot+VUE實現(xiàn)數(shù)據(jù)表格的實戰(zhàn)

    SpringBoot+VUE實現(xiàn)數(shù)據(jù)表格的實戰(zhàn)

    本文將使用VUE+SpringBoot+MybatisPlus,以前后端分離的形式來實現(xiàn)數(shù)據(jù)表格在前端的渲染,具有一定的參考價值,感興趣的可以了解一下
    2021-08-08
  • Java HashMap三種循環(huán)遍歷方式及其性能對比實例分析

    Java HashMap三種循環(huán)遍歷方式及其性能對比實例分析

    這篇文章主要介紹了Java HashMap三種循環(huán)遍歷方式及其性能對比,結(jié)合具體實例形式分析了Java HashMap三種循環(huán)遍歷方式的實現(xiàn)方法、運行效率及性能優(yōu)劣,需要的朋友可以參考下
    2019-10-10
  • 解析Java設(shè)計模式編程中命令模式的使用

    解析Java設(shè)計模式編程中命令模式的使用

    這篇文章主要介紹了Java設(shè)計模式編程中命令模式的使用,在一些處理請求響應(yīng)的場合經(jīng)常可以用到命令模式的編程思路,需要的朋友可以參考下
    2016-02-02
  • 使用HttpClient實現(xiàn)文件的上傳下載方法

    使用HttpClient實現(xiàn)文件的上傳下載方法

    下面小編就為大家?guī)硪黄褂肏ttpClient實現(xiàn)文件的上傳下載方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • MyBatis?@Select注解介紹:基本用法與動態(tài)SQL拼寫方式

    MyBatis?@Select注解介紹:基本用法與動態(tài)SQL拼寫方式

    這篇文章主要介紹了MyBatis?@Select注解介紹:基本用法與動態(tài)SQL拼寫方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • java中的BlockingQueue(阻塞隊列)解析

    java中的BlockingQueue(阻塞隊列)解析

    這篇文章主要介紹了java中的BlockingQueue阻塞隊列解析,阻塞隊列是一個支持兩個附加操作的隊列,這兩個附加的操作是,在隊列為空時,獲取元素的線程會等待隊列變?yōu)榉强?需要的朋友可以參考下
    2023-12-12
  • java 多線程實現(xiàn)在線咨詢(udp)

    java 多線程實現(xiàn)在線咨詢(udp)

    這篇文章主要介紹了java 多線程實現(xiàn)在線咨詢(udp)的示例,幫助大家更好的理解和學(xué)習(xí)Java 網(wǎng)絡(luò)編程的相關(guān)內(nèi)容,感興趣的朋友可以了解下
    2020-11-11
  • Java如何通過屬性名獲取Object對象屬性值

    Java如何通過屬性名獲取Object對象屬性值

    這篇文章主要介紹了Java如何通過屬性名獲取Object對象屬性值問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • spring/springboot整合curator遇到的坑及解決

    spring/springboot整合curator遇到的坑及解決

    這篇文章主要介紹了spring/springboot整合curator遇到的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05

最新評論