java稀疏數(shù)組的示例代碼
稀疏組織
- 當(dāng)一個數(shù)組中大部分元素為0,或者為同一個值的數(shù)組時,可以用稀疏數(shù)組來保存該數(shù)組
- 稀疏數(shù)組,記錄一共有幾行幾列,有多少個不同值
- 把具有不同值的元素和行里了及值記錄在一個小規(guī)模的數(shù)組中,從而縮小程序的規(guī)模!
我們定義一下原始數(shù)組:
原始數(shù)組如下: 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
可以看出,這個數(shù)組大部分都是0,我們可以把這個數(shù)組轉(zhuǎn)化為稀疏數(shù)組
稀疏數(shù)組第一行存放的分別是總行數(shù),總列數(shù)和存放的數(shù)據(jù)總數(shù)
//因?yàn)閿?shù)組的下標(biāo)是從0開始的,所以可以看出,第一行的第三個數(shù),用下標(biāo)表示,實(shí)際上是數(shù)組[0][2] 5 5 4 0 2 3 1 4 4 2 3 5 3 2 6
下面看一下如何實(shí)現(xiàn)這種稀疏數(shù)組,又是如何把稀疏數(shù)組還原成
代碼示例:
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("原始數(shù)組如下:");
for (int[] ints : array) {
for (int anInt : ints) {
System.out.print(anInt+" ");
}
System.out.println();
}
System.out.println("行"+"\t"+"列"+"\t"+"存放的數(shù)據(jù)"+"\t");
//稀疏數(shù)組第一行存放的分別是總行數(shù),總列數(shù)和存放的數(shù)據(jù)總數(shù)
// 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];
//這個二維數(shù)組的第一行是確定的
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("輸出稀疏數(shù)組");
for (int[] ints : arr2) {
for (int anInt : ints) {
System.out.print(anInt+" ");
}
System.out.println();
}
}
}
輸出:
輸出原始的數(shù)組
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
有效值的個數(shù):2
輸出稀疏數(shù)組:
11 11 2
1 2 1
3 2 2
=========分========割==========線=============
我們也可以把稀疏數(shù)組進(jìn)行一個還原
打印還原后的數(shù)組
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
以上就是關(guān)于稀疏數(shù)組的講解,有不理解的可以跟著代碼試一下,然后自己創(chuàng)建一個數(shù)組,并把數(shù)組轉(zhuǎn)換為稀疏數(shù)組!再試著轉(zhuǎn)換回來。
到此這篇關(guān)于java稀疏數(shù)組的文章就介紹到這了,更多相關(guān)java稀疏數(shù)組內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Java把文本內(nèi)容轉(zhuǎn)換成網(wǎng)頁的實(shí)現(xiàn)方法分享
這篇文章主要介紹了使用Java把文本內(nèi)容轉(zhuǎn)換成網(wǎng)頁的實(shí)現(xiàn)方法分享,利用到了Java中的文件io包,需要的朋友可以參考下2015-11-11
Spring學(xué)習(xí)之動態(tài)代理(JDK動態(tài)代理和CGLIB動態(tài)代理)
本篇文章主要介紹了Spring學(xué)習(xí)之動態(tài)代理(JDK動態(tài)代理和CGLIB動態(tài)代理),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07
Spring配置動態(tài)數(shù)據(jù)源實(shí)現(xiàn)讀寫分離的方法
這篇文章主要介紹了利用Spring配置動態(tài)數(shù)據(jù)源實(shí)現(xiàn)讀寫分離的方法,文中通過示例代碼介紹的很詳細(xì),相信對大家的理解和學(xué)習(xí)具有一定的參考借鑒價值,藕需要的朋友可以一起學(xué)習(xí)學(xué)習(xí)。2017-01-01
Java+Selenium實(shí)現(xiàn)控制瀏覽器的啟動選項(xiàng)Options
這篇文章主要為大家詳細(xì)介紹了如何使用java代碼利用selenium控制瀏覽器的啟動選項(xiàng)Options的代碼操作,文中的示例代碼講解詳細(xì),感興趣的可以了解一下2023-01-01

