稀疏数组
这一章是我很头疼的一章,说实话
package com.HuoLong.array;
?
public class ArrayDemo09 {
public static void main(String[] args) {
//创建一个二位数组11*11
int[][] array1=new int[11][11];
?
array1[1][2]=1;
array1[2][3]=2;
//输出原始数组
System.out.println("输出原始数组");
?
//打印二维数组
for (int[] ints : array1) {//array1.for
for (int anInt : ints) {//ints,for
System.out.print(anInt+"\t");//anInt打印每行 每个元素隔开
}
System.out.println();//换行
}
System.out.println("=============");
//转换稀疏数组
//获取有效值的个数
int sum =0;
for (int i = 0; i < 11; i++) {
for (int j = 0; j < 11; j++) {
if (array1[i][j]!=0) {
sum++;
}
}
}
System.out.println("有效值的个数:"+sum);
?
//2.创建一个稀疏数组
int[][] array2=new int[sum+1][3];
?
array2[0][0]=11;//行
array2[0][1]=11;//列
array2[0][2]=sum;//有效值个数
?
//遍历二维数组 将非零的值 存放在稀疏数组中
int count=0;
for (int i = 0; i < array1.length ;i++) {
for (int j = 0; j < array1[i].length; j++) {
if (array1[i][j]!=0){
count++;
array2[count][0]=i;//行
array2[count][1]=j;//列
array2[count][2]=array1[i][j];
}
}
}
System.out.println("稀疏数组");