java实现稀疏数组压缩

package sparseArray;

public class SparseArray {
    

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        //创建一个原始的二维数组
        // 0表示没有棋子,1表示黑子,2表示蓝子
        int chessArr1[][] =new int[11][11];
        chessArr1[1][2]=1;
        chessArr1[2][3]=2;
        //输出原始二维数组
        System.out.println("原始的二维数组:");
        for(int [] row:chessArr1)
        {
            for (int data:row)
            {
                System.out.printf("%d\t",data);
            }
            System.out.println();
        }
        //将二维数组转化成稀疏数组
        //先遍历二维数组,获取非零元素的个数
        int sum=0;
        for(int i=0;i<chessArr1.length;i++)
        {
            for(int j=0;j<chessArr1[0].length;j++)
            {
                if(chessArr1[i][j]!=0)
                {
                    sum++;
                }
            }
        }
        //创建对应的一个稀疏数组
        int sparseArr2[][]=new int[sum+1][3];
        //给稀疏数组赋值
        sparseArr2[0][0]=11;
        sparseArr2[0][1]=11;
        sparseArr2[0][2]=sum;
        int index=1;//稀疏数组的下标,记录是第几个非零数据
        //遍历二维数组,将非零的值,存储到稀疏数组中
        for(int i=0;i<chessArr1.length;i++)
        {
            for(int j=0;j<chessArr1[0].length;j++)
            {
                if(chessArr1[i][j]!=0)
                {
                    sparseArr2[index][0]=i;
                    sparseArr2[index][1]=j;
                    sparseArr2[index][2]=chessArr1[i][j];
                    index++;
                }
            }
        }
        
        //输出稀疏数组的形式
        System.out.println("得到的稀疏数组为如下形式:");
        for(int i=0;i<sparseArr2.length;i++)
        {
            System.out.printf("%d\t%d\t%d\t",sparseArr2[i][0],sparseArr2[i][1],sparseArr2[i][2]);
            System.out.println();
        }
        //将稀疏数组回复称原来的二维数组
        //先读取稀疏数组的第一行
        //赋值给对应数组就好了
        int chessArr3[][]=new int[sparseArr2[0][0]][sparseArr2[0][1]];
        //循环赋值
        for(int i=1;i<sparseArr2.length;i++)
        {
            chessArr3[sparseArr2[i][0]][sparseArr2[i][1]]=sparseArr2[i][2];
        }
        //////////////////////////
        System.out.println("输出恢复后的二维数组:");
        for(int i=0;i<sparseArr2[0][0];i++)
        {
            for(int j=0;j<sparseArr2[0][1];j++)
            {
                System.out.printf("%d\t",chessArr3[i][j]);
            }
            System.out.println();
        }
    }

}

 

posted @ 2019-07-13 15:37  梦小冷  阅读(629)  评论(0编辑  收藏  举报