稀疏數(shù)組

稀疏數(shù)組

當(dāng)一個(gè)數(shù)組中大部分元素為0诡壁,或者為同一值的數(shù)組時(shí)鬓椭,可以使用稀疏數(shù)組來保存該數(shù)組昨寞。
稀疏數(shù)組的處理方式是:記錄數(shù)組一共有幾行幾列,有多少個(gè)不同值括袒;把具有不同值的元素和行列及值記錄在一個(gè)小規(guī)模的數(shù)組中次兆,從而縮小程序的規(guī)模
,為了節(jié)約空間起到壓縮的效果锹锰,將數(shù)據(jù)用另一種結(jié)構(gòu)來表示芥炭,即稀疏數(shù)組

形式

二維數(shù)組
0 0 0
0 1 0
0 0 0
0 0 0
稀疏數(shù)組
4 3 1
1 1 1

code


public class Test {

    public static void main(String[] args) throws IOException {
        int [][] arr = {{0,0,0},{0,1,0},{0,0,0},{0,0,0}};
        System.out.println("二維數(shù)組:");
        for(int i = 0; i < arr.length; i ++) {
            for(int j = 0; j < arr[i].length; j ++) {
                System.out.printf("%d\t", arr[i][j]);
            }
            System.out.println();
        }

        //創(chuàng)建稀疏數(shù)組
        int sum = 0;
        for(int i = 0; i < arr.length; i ++) {
            for(int j = 0; j < arr[i].length; j ++) {
                if(arr[i][j] != 0) {
                    sum ++;
                }
            }
        }

        int [][] sparseArr = new int[sum + 1][3];
        sparseArr[0][0] = 4;
        sparseArr[0][1] = 3;
        sparseArr[0][2] = 1;

        int count = 0;
        for(int i = 0; i < arr.length; i ++) {
            for(int j = 0; j < arr[i].length; j ++) {
                if(arr[i][j] != 0) {
                    count ++;
                    sparseArr[count][0] = i;
                    sparseArr[count][1] = j;
                    sparseArr[count][2] = arr[i][j];
                }
            }
        }

        System.out.println("二維數(shù)組轉(zhuǎn)稀疏數(shù)組:");
        for(int i = 0; i < sparseArr.length; i ++) {
            for(int j = 0; j < sparseArr[i].length; j ++) {
                System.out.printf("%d\t", sparseArr[i][j]);
            }
            System.out.println();
        }

        //稀疏數(shù)組轉(zhuǎn)二維數(shù)組
        int[][] newArr = new int[sparseArr[0][0]][sparseArr[0][1]];
        int count2 = sparseArr[0][2];

        for(int i = 1; i < sparseArr.length; i ++) {
            //將稀疏數(shù)組的有數(shù)據(jù)的,記錄在二維數(shù)組
            newArr[sparseArr[i][0]][sparseArr[i][1]] = sparseArr[i][2];
        }

        //輸出轉(zhuǎn)換后二維數(shù)組
        System.out.println("稀疏數(shù)組轉(zhuǎn)二維數(shù)組:");
        for(int i = 0; i < newArr.length; i ++) {
            for(int j = 0; j < newArr[i].length; j ++) {
                System.out.printf("%d\t", newArr[i][j]);
            }

            System.out.println();
        }


//        System.out.printf("%d\t", 1);
        System.out.println("讀取文件稀疏數(shù)據(jù)");
        //讀取文件稀疏數(shù)據(jù)
        int[][] ints = readFile();



    }

    //把稀疏數(shù)組存入本地文件txt
    public static void writeFile() {

    }
    //讀取本地文件稀疏數(shù)組
    public static int[][] readFile() throws IOException {
//
        //模擬文件
        File file = new File("D:/sparseArr.txt");
        //將file轉(zhuǎn)字符字符輸入流
        FileInputStream fileInputStream = new FileInputStream(file);
        //將字符輸入流轉(zhuǎn)成buffer,可以逐行讀
        BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(fileInputStream));

        //稀疏數(shù)組
        int cols = 3;
        int rows = 0;
        int sum = 0;
        //讀取一行
        String content = bufferedReader.readLine();
        if(Strings.isNotBlank(content)) {
            String substring = content.substring(1, 2);
            String[] split = content.split(substring);
            rows = Integer.valueOf(split[0]);
            cols = Integer.valueOf(split[1]);
            sum = Integer.valueOf(split[2]);
        }
        System.out.printf("rows:%d,cols:%d,sum:%d\n", rows,cols, sum);

        //解析除了第一行恃慧,稀疏數(shù)組組裝
        int[][] sparseArr = new int[sum + 1][cols];
        sparseArr[0][0] = rows;
        sparseArr[0][1] = cols;
        sparseArr[0][2] = sum;
        int count = 0;
        BufferedReader bufferedReader1 = new BufferedReader(new InputStreamReader(fileInputStream));
        String content2 = bufferedReader1.readLine();
        while (Strings.isNotBlank(content2)) {
            String substring = content2.substring(1, 2);
            String[] split = content2.split(substring);
            if(count >= 1) {//只處理第二行數(shù)據(jù)
                sparseArr[count][0] = Integer.valueOf(split[0]);
                sparseArr[count][1] = Integer.valueOf(split[1]);
                sparseArr[count][2] = Integer.valueOf(split[2]);
            }
            //讀取下一行
            content2 = bufferedReader.readLine();
        }

        //打印解析后的稀疏數(shù)組
        System.out.println("打印解析后的稀疏數(shù)組:");
        for(int i = 0; i < sparseArr.length; i ++) {
            for(int j = 0; j < sparseArr[0].length; j ++) {
                System.out.printf("%d\t", sparseArr[i][j]);
            }
            System.out.println();
        }

//        int[][] sparseArr= new int[3][];

        
        return null;

    }
}

console

二維數(shù)組:
0   0   0   
0   1   0   
0   0   0   
0   0   0   
二維數(shù)組轉(zhuǎn)稀疏數(shù)組:
4   3   1   
1   1   1   
稀疏數(shù)組轉(zhuǎn)二維數(shù)組:
0   0   0   
0   1   0   
0   0   0   
0   0   0   
讀取文件稀疏數(shù)據(jù)
rows:4,cols:3,sum:1
打印解析后的稀疏數(shù)組:
4   3   1   
0   0   0

場(chǎng)景

棋盤記錄

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末园蝠,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子痢士,更是在濱河造成了極大的恐慌砰琢,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,402評(píng)論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件良瞧,死亡現(xiàn)場(chǎng)離奇詭異陪汽,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)褥蚯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門挚冤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人赞庶,你說我怎么就攤上這事训挡。” “怎么了歧强?”我有些...
    開封第一講書人閱讀 162,483評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵澜薄,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我摊册,道長(zhǎng)肤京,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,165評(píng)論 1 292
  • 正文 為了忘掉前任茅特,我火速辦了婚禮忘分,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘白修。我一直安慰自己妒峦,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,176評(píng)論 6 388
  • 文/花漫 我一把揭開白布兵睛。 她就那樣靜靜地躺著肯骇,像睡著了一般窥浪。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上笛丙,一...
    開封第一講書人閱讀 51,146評(píng)論 1 297
  • 那天漾脂,我揣著相機(jī)與錄音,去河邊找鬼若债。 笑死符相,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蠢琳。 我是一名探鬼主播啊终,決...
    沈念sama閱讀 40,032評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼傲须!你這毒婦竟也來了蓝牲?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,896評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤泰讽,失蹤者是張志新(化名)和其女友劉穎例衍,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體已卸,經(jīng)...
    沈念sama閱讀 45,311評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡佛玄,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,536評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了累澡。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片梦抢。...
    茶點(diǎn)故事閱讀 39,696評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖愧哟,靈堂內(nèi)的尸體忽然破棺而出奥吩,到底是詐尸還是另有隱情,我是刑警寧澤蕊梧,帶...
    沈念sama閱讀 35,413評(píng)論 5 343
  • 正文 年R本政府宣布霞赫,位于F島的核電站,受9級(jí)特大地震影響肥矢,放射性物質(zhì)發(fā)生泄漏端衰。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,008評(píng)論 3 325
  • 文/蒙蒙 一橄抹、第九天 我趴在偏房一處隱蔽的房頂上張望靴迫。 院中可真熱鬧,春花似錦楼誓、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春榄融,著一層夾襖步出監(jiān)牢的瞬間参淫,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,815評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工愧杯, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留涎才,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,698評(píng)論 2 368
  • 正文 我出身青樓力九,卻偏偏與公主長(zhǎng)得像耍铜,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子跌前,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,592評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容