码迷,mamicode.com
首页 > 编程语言 > 详细

将二维数组转为稀疏数组

时间:2020-04-10 18:34:53      阅读:66      评论:0      收藏:0      [点我收藏+]

标签:遍历   count   highlight   图片   array   二维   image   public   for   

public class SparseArray {
	/**
	 * 用二维数组实现一个棋盘,1代表黑子,2代表蓝子
	 */
	public static void main(String[] args) {
		/**
		 * 二维数组
		 */
		int[][] chessArray1 = new int[11][11];
		chessArray1[1][2] = 1;
		chessArray1[2][3] = 2;
		for (int[] row : chessArray1) {
			for (int data : row) {
				System.out.printf("%d\t", data);
			}
			System.out.println();
		}
		System.out.println("_________________________________________________________________________________");
		/**
		 * 将此二维数组转为稀疏数组
		 */
		// 先遍历二维数组,得到有几个非零数据
		int sum = 0;
		for (int[] row : chessArray1) {
			for (int data : row) {
				if (data != 0) {
					sum++;
				}
			}
		}
		// 构造稀疏数组
		int[][] sparseArray = new int[sum + 1][3];
		sparseArray[0][0] = chessArray1.length;
		sparseArray[0][1] = chessArray1[0].length;
		sparseArray[0][2] = sum;
		// 遍历二维数组,并将非零元素填充到稀疏数组中
		int count = 0;
		for (int i = 0; i < chessArray1.length; i++) {
			for (int j = 0; j < chessArray1[0].length; j++) {
				if (chessArray1[i][j] != 0) {
					count++;
					sparseArray[count][0] = i;
					sparseArray[count][1] = j;
					sparseArray[count][2] = chessArray1[i][j];
				}
			}
		}
		// 打印稀疏数组
		for (int[] row : sparseArray) {
			for (int data : row) {
				System.out.printf("%d\t", data);
			}
			System.out.println();
		}
	}

}

  技术图片

 

将二维数组转为稀疏数组

标签:遍历   count   highlight   图片   array   二维   image   public   for   

原文地址:https://www.cnblogs.com/dashenaichicha/p/12675087.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!