Java数组04-稀疏数组

稀疏数组

  • 当数组中大部分元素为0,或者为同一值的数组时,可以使用稀疏数组来保存该数组

  • 稀疏数组的处理方式:

    • 记录数组一共有几行几列,有多少个不同值

    • 把具有不同值的元素和行列及值记录在一个小规模的数组中,从而缩小程序的规模

 

 

 package array;
 
 /**
  * @author IT_Jay
  * @date 2022/1/21 20:10
  */
 
 public class arrayDemo08 {
     public static void main(String[] args) {
 
         //创建一个二维数组 11*11 0:无棋子 1:黑棋   2:白棋
         int[][] array1 = new int[11][11];
         array1[1][2] = 1;
         array1[2][3] = 2;
         //输出原始的数组
         System.out.println("输出原始的数组:");
 
         for (int[] ints : array1) {
             for (int anInt : ints) {
                 System.out.print(anInt + "\t");
            }
             System.out.println();
        }
 
         System.out.println("========================================================");
         //转换为稀疏数组
         //获取有效值的个数
         int s = 0;
         for (int i = 0; i < array1.length; i++) {
             for (int j = 0; j < array1[i].length; j++) {            //注意此时内层for循环,array1[i].length
                 if (array1[i][j] != 0) {
                     s++;
                }
            }
        }
         System.out.println("有效值的个数为:" + s);
         System.out.println("========================================================");
 
         //2、创建一个稀疏数组
         int[][] array2 = new int[s + 1][3];
         //稀疏数组第一行内容(下标从0开始)
         array2[0][0] = 11;
         array2[0][1] = 11;
         array2[0][2] = s;
 
         //遍历二维数组,将非零值存入稀疏数组
         int count = 0;
         for (int i = 0; i < array1.length; i++) {
             for (int j = 0; j < array1[i].length; j++) {                //注意此时内层for循环,array1[i].length
                 if (array1[i][j] != 0){
                     count++;
                     array2[count][0]=i;     //当找第一个非0元素时,count=1,则二维数组array2第2行(下标为1,从0开始)第一个元素存入非0元素的横坐标
                     array2[count][1]=j;     //当找第一个非0元素时,count=1,则二维数组array2第2行第二个元素存入非0元素的纵坐标
                     array2[count][2]=array1[i][j];      //当找第一个非0元素时,count=1,则二维数组array2第2行第三个元素存入非0元素的值
                }
            }
        }
 
         //输出稀疏数组
         System.out.println("输出稀疏数组:");
         for (int i = 0; i<array2.length;i++){
             System.out.println(array2[i][0]+"\t"
                                 +array2[i][1]+"\t"
                                 +array2[i][2]+"\t");
        }
 
         System.out.println("========================================================");
         System.out.println("将稀疏数组还原:");
 
         //1、读取稀疏数组的值
         int[][] array3 = new int[array2[0][0]][array2[0][1]];           //稀疏数组第一行第一个元素为原数组行数,第二个元素为原数组列数
 
         //2、还原数组中值
 //       array3[array2[1][0]][array2[1][1]]=array2[1][2];
 //       array3[array2[2][0]][array2[2][1]]=array2[2][2];
         for (int i = 1; i < array2.length; i++) {       //注意此时i=1,因为稀疏数组第一行记录的是array1的行数,列数,非0值个数,第二行才是非0元素横坐标,纵坐标,元素值
             array3[array2[i][0]][array2[i][1]]=array2[i][2];
        }
 
         //3、打印
         for (int[] ints : array3) {
             for (int anInt : ints) {
                 System.out.print(anInt + "\t");
            }
             System.out.println();
        }
    }
 }

 

 

 

posted @   作困兽之斗  阅读(203)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示