亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

淺談Java數(shù)據(jù)結(jié)構(gòu)之稀疏數(shù)組知識(shí)總結(jié)

 更新時(shí)間:2021年05月25日 08:53:27   作者:xdmx  
今天帶大家了解一下Java稀疏數(shù)組的相關(guān)知識(shí),文中有非常詳細(xì)的介紹及代碼示例,對(duì)正在學(xué)習(xí)java的小伙伴們有很好地幫助,需要的朋友可以參考下

稀疏數(shù)組

  • 當(dāng)一個(gè)數(shù)組中的元素大多為0或者相同元素的時(shí)候,可以用稀疏數(shù)組來(lái)壓縮
  • 稀疏數(shù)組只記錄 行row 列col 值value

將下列的二維數(shù)組轉(zhuǎn)為稀疏數(shù)組,如下兩圖所示

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

1.實(shí)現(xiàn)二維數(shù)組轉(zhuǎn)為稀疏數(shù)組的步驟:

  • 遍歷數(shù)組,得到數(shù)組中 不為0的個(gè)數(shù),并記錄為sum,作為稀疏數(shù)組第0行的 value
  • 遍歷數(shù)組,將數(shù)組中不為0的數(shù)的行和列和值分別寫(xiě)入稀疏數(shù)組的 row col val 中

代碼實(shí)現(xiàn):

public class SparseArray {
    public static void main(String[] args) {

        // 創(chuàng)建一個(gè)原始二維數(shù)組
        // 0表示沒(méi)有棋子,1,2各表示一種棋
        int chessArr[][] = new int[8][8];
        chessArr[1][1] = 1;
        chessArr[2][2] = 2;

        // 遍歷原始數(shù)組,獲得不等于 0 的個(gè)數(shù),并輸出原始數(shù)組
        int sum = 0;
        System.out.println("原始數(shù)組:");
        for (int[] ints : chessArr) {
            for (int anInt : ints) {
                System.out.print(anInt+"\t");
                if (anInt != 0){
                    sum++;
                }
            }
            System.out.println();
        }
        System.out.println(sum);

        // 創(chuàng)建稀疏數(shù)組并賦值
        int sparseArray[][] = new int[sum+1][3];
        int row = chessArr.length; // 原數(shù)組的行數(shù)
        int col = chessArr[0].length; // 原數(shù)組的列數(shù)
        sparseArray[0][0] = row;
        sparseArray[0][1] = col;
        sparseArray[0][2] = sum;

        // 遍歷原始數(shù)組并賦值給稀疏數(shù)組
        int count = 0; // count 為計(jì)數(shù)器
        for (int i = 0;i < row;i++) {
            for (int j = 0;j < col;j++) {
                if (chessArr[i][j] != 0) {
                    count++;
                    sparseArray[count][0] = i;
                    sparseArray[count][1] = j;
                    sparseArray[count][2] = chessArr[i][j];
                }
            }
        }

        // 輸出得到的稀疏數(shù)組
        System.out.println("稀疏數(shù)組為:");
        for (int i = 0 ;i < sparseArray.length;i++) {
            System.out.println(sparseArray[i][0]+"\t"+sparseArray[i][1]+"\t"+sparseArray[i][2]);
        }

    }
}

2.實(shí)現(xiàn)二維數(shù)組轉(zhuǎn)稀疏數(shù)組的步驟

  • 根據(jù)稀疏數(shù)組的第一行創(chuàng)建新的二維數(shù)組
  • 遍歷稀疏數(shù)組,將row col val 賦給新的二維數(shù)組

代碼實(shí)現(xiàn):

public class SparseArray {
    public static void main(String[] args) {
        
        
		...... // 接上一段代碼
            
            
        // 輸出得到的稀疏數(shù)組
        System.out.println("稀疏數(shù)組為:");
        for (int i = 0 ;i < sparseArray.length;i++) {
            System.out.println(sparseArray[i][0]+"\t"+sparseArray[i][1]+"\t"+sparseArray[i][2]);
        }

        // 創(chuàng)建新的二維數(shù)組
        int newChessArray[][] = new int[sparseArray[0][0]][sparseArray[0][1]];
        for (int i = 1 ;i < sparseArray.length;i++) {
            newChessArray[sparseArray[i][0]][sparseArray[i][1]] = sparseArray[i][2];
        }

        // 輸出新的二維數(shù)組
        System.out.println("恢復(fù)后的二維數(shù)組是:");
        for (int[] ints : newChessArray) {
            for (int anInt : ints) {
                System.out.print(anInt+"\t");
            }
            System.out.println();
        }
    }
}

3.將稀疏數(shù)組寫(xiě)入磁盤(pán)

public static void main(String[] args) {
    ........
	// 將稀疏數(shù)組存入磁盤(pán)
    FileOutputStream fw = null;
    try {
        fw = new FileOutputStream("sparseArray.txt");
        // 遍歷寫(xiě)入磁盤(pán)
        for (int i = 0; i < sparseArray.length; i++) {
            for (int j = 0; j < 3; j++) {
                fw.write(sparseArray[i][j]);
            }
        }
        fw.flush();
    } catch (FileNotFoundException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    } finally {
        if (fw != null){
            fw.close();
        }
    }
}

4.從磁盤(pán)讀取稀疏數(shù)組

public static void main(String[] args) {
    .......
    // 從磁盤(pán)讀取稀疏數(shù)組
    FileInputStream fi = null;
    int newSparseArray[][] = new int[sum+1][3];  // sum 指前面二維數(shù)組有值的個(gè)數(shù)
    try {
        fi = new FileInputStream("sparseArray.txt");
        for (int i = 0;i < newSparseArray.length;i++) {
            for (int j = 0;j < 3;j++){
                newSparseArray[i][j] = fi.read();
            }
        }
    } catch (FileNotFoundException e){
        e.printStackTrace();
    } finally {
        if (fi != null){
            fi.close();
        }
    }
}

到此這篇關(guān)于淺談Java數(shù)據(jù)結(jié)構(gòu)之稀疏數(shù)組知識(shí)總結(jié)的文章就介紹到這了,更多相關(guān)Java稀疏數(shù)組內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • javafx實(shí)現(xiàn)時(shí)鐘效果

    javafx實(shí)現(xiàn)時(shí)鐘效果

    這篇文章主要為大家詳細(xì)介紹了javafx實(shí)現(xiàn)時(shí)鐘效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • java實(shí)現(xiàn)在普通類中注入service或mapper

    java實(shí)現(xiàn)在普通類中注入service或mapper

    這篇文章主要介紹了java實(shí)現(xiàn)在普通類中注入service或mapper的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • feign的ribbon超時(shí)配置和hystrix的超時(shí)配置說(shuō)明

    feign的ribbon超時(shí)配置和hystrix的超時(shí)配置說(shuō)明

    這篇文章主要介紹了feign的ribbon超時(shí)配置和hystrix的超時(shí)配置說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-09-09
  • 詳解SpringMVC中設(shè)置靜態(tài)資源不被攔截的問(wèn)題

    詳解SpringMVC中設(shè)置靜態(tài)資源不被攔截的問(wèn)題

    這篇文章主要介紹了詳解SpringMVC中設(shè)置靜態(tài)資源不被攔截的問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-02-02
  • 自定義指定路由上的Gateway過(guò)濾器工廠詳解

    自定義指定路由上的Gateway過(guò)濾器工廠詳解

    這篇文章主要介紹了自定義指定路由上的Gateway過(guò)濾器工廠詳解,gateway是Spring?Cloud中的一個(gè)網(wǎng)關(guān)服務(wù),gateway可以使用服務(wù)注冊(cè)中心進(jìn)行服務(wù)發(fā)現(xiàn)和負(fù)載均衡,同時(shí)還可以配置斷言來(lái)判斷請(qǐng)求是否符合路由規(guī)則,需要的朋友可以參考下
    2023-09-09
  • SpringMVC中的http Caching的具體使用

    SpringMVC中的http Caching的具體使用

    本文主要介紹了SpringMVC中的http Caching的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • MyBatisPlus利用Service實(shí)現(xiàn)獲取數(shù)據(jù)列表

    MyBatisPlus利用Service實(shí)現(xiàn)獲取數(shù)據(jù)列表

    這篇文章主要為大家詳細(xì)介紹了怎樣使用 IServer 提供的 list 方法查詢多條數(shù)據(jù),這些方法將根據(jù)查詢條件獲取多條數(shù)據(jù),感興趣的可以了解一下
    2022-06-06
  • 基于JavaMail的常用類詳細(xì)介紹

    基于JavaMail的常用類詳細(xì)介紹

    以下是對(duì)JavaMail的常用類進(jìn)行了詳細(xì)分析的介紹,需要的朋友可以過(guò)來(lái)參考下
    2013-09-09
  • MyBatis-Plus插件機(jī)制及通用Service新功能

    MyBatis-Plus插件機(jī)制及通用Service新功能

    這篇文章主要介紹了MyBatis-Plus插件機(jī)制以及通用Service、新功能,本文通過(guò)實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • Java System類用法實(shí)戰(zhàn)案例

    Java System類用法實(shí)戰(zhàn)案例

    這篇文章主要介紹了Java System類用法,結(jié)合具體實(shí)例形式分析了java使用System類獲取系統(tǒng)環(huán)境變量信息相關(guān)操作技巧,需要的朋友可以參考下
    2019-07-07

最新評(píng)論