1. 程式人生 > 其它 >CSS學習筆記(一)-16.盒子模型-盒子陰影

CSS學習筆記(一)-16.盒子模型-盒子陰影

稀疏 sparsearray 陣列

 編寫的五子棋程式中,有存檔退出和續上盤的功能。

 分析問題:

因為該二維陣列的很多值是預設值 0, 因此記錄了很多沒有意義的資料.->稀疏陣列

當一個數組中大部分元素為0,或者為同一個值的陣列時,可以使用稀疏陣列來儲存該陣列。

稀疏陣列的處理方法是:

1) 記錄陣列一共有幾行幾列,有多少個不同的值

2) 把具有不同值的元素的行列及值記錄在一個小規模的陣列中,從而縮小程式的規模

應用例項

1) 使用稀疏陣列,來保留類似前面的二維陣列(棋盤、地圖等等)

2) 把稀疏陣列存檔,並且可以從新恢復原來的二維陣列數

3) 整體思路分析

4) 程式碼實現

點選檢視程式碼
public class SparseArray {

	public static void main(String[] args) {
		// 建立一個原始的二維陣列 11 * 11
		// 0: 表示沒有棋子, 1 表示 黑子 2 表藍子
		int chessArr1[][] = new int[11][11];
		chessArr1[1][2] = 1;
		chessArr1[2][3] = 2;
		chessArr1[4][5] = 2;
		// 輸出原始的二維陣列
		System.out.println("原始的二維陣列~~");
		for (int[] row : chessArr1) {
			for (int data : row) {
				System.out.printf("%d\t", data);
			}
			System.out.println();
		}

		// 將二維陣列 轉 稀疏陣列的思
		// 1. 先遍歷二維陣列 得到非0資料的個數
		int sum = 0;
		for (int i = 0; i < 11; i++) {
			for (int j = 0; j < 11; j++) {
				if (chessArr1[i][j] != 0) {
					sum++;
				}
			}
		}

		// 2. 建立對應的稀疏陣列
		int sparseArr[][] = new int[sum + 1][3];
		// 給稀疏陣列賦值
		sparseArr[0][0] = 11;
		sparseArr[0][1] = 11;
		sparseArr[0][2] = sum;
		
		// 遍歷二維陣列,將非0的值存放到 sparseArr中
		int count = 0; //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];
				}
			}
		}
		
		// 輸出稀疏陣列的形式
		System.out.println();
		System.out.println("得到稀疏陣列為~~~~");
		for (int i = 0; i < sparseArr.length; i++) {
			System.out.printf("%d\t%d\t%d\t\n", sparseArr[i][0], sparseArr[i][1], sparseArr[i][2]);
		}
		System.out.println();
		
		//將稀疏陣列 --》 恢復成 原始的二維陣列
		/*
		 *  1. 先讀取稀疏陣列的第一行,根據第一行的資料,建立原始的二維陣列,比如上面的  chessArr2 = int [11][11]
			2. 在讀取稀疏陣列後幾行的資料,並賦給 原始的二維陣列 即可.
		 */
		
		//1. 先讀取稀疏陣列的第一行,根據第一行的資料,建立原始的二維陣列
		
		int chessArr2[][] = new int[sparseArr[0][0]][sparseArr[0][1]];
		
		//2. 在讀取稀疏陣列後幾行的資料(從第二行開始),並賦給 原始的二維陣列 即可
		
		for(int i = 1; i < sparseArr.length; i++) {
			chessArr2[sparseArr[i][0]][sparseArr[i][1]] = sparseArr[i][2];
		}
		
		// 輸出恢復後的二維陣列
		System.out.println();
		System.out.println("恢復後的二維陣列");
		
		for (int[] row : chessArr2) {
			for (int data : row) {
				System.out.printf("%d\t", data);
			}
			System.out.println();
		}
	}

}

課後練習

要求:

1) 在前面的基礎上,將稀疏陣列儲存到磁碟上,比如 map.data

2) 恢復原來的陣列時,讀取 map.data 進行恢復