배열의 요소 대부분이 0이거나 동일한 값의 배열인 경우 희소 배열을 사용하여 배열을 저장할 수 있습니다.
희소 배열은 행과 열의 수를 기록합니다. . 얼마나 많은 값이 있는지
서로 다른 값을 갖는 요소와 행을 작은 배열에 기록하여 프로그램 크기를 줄입니다!
원래 배열을 정의해 보겠습니다.
原始数组如下: 0 0 3 0 0 0 0 0 0 4 0 0 0 5 0 0 0 6 0 0 0 0 0 0 0
이 배열의 대부분이 0인 것을 볼 수 있습니다. 이 배열을 희소 배열로 변환할 수 있습니다
희소 배열의 첫 번째 행은 총 행 수를 저장하고 총 열 개수와 저장된 데이터의 총 개수
//因为数组的下标是从0开始的,所以可以看出,第一行的第三个数,用下标表示,实际上是数组[0][2] 5 5 4 0 2 3 1 4 4 2 3 5 3 2 6
이 희소 배열을 구현하는 방법과 희소 배열을
로 복원하는 방법을 살펴보겠습니다.코드 예:
package com.ling.array; public class ArrayDemo11 { public static void main(String[] args) { int[][] array=new int[5][5]; array[0][2]=3; array[1][4]=4; array[2][3]=5; array[3][2]=6; System.out.println("原始数组如下:"); for (int[] ints : array) { for (int anInt : ints) { System.out.print(anInt+" "); } System.out.println(); } System.out.println("行"+"\t"+"列"+"\t"+"存放的数据"+"\t"); //稀疏数组第一行存放的分别是总行数,总列数和存放的数据总数 // System.out.println(5+"\t"+5+"\t"+4); // System.out.println(1+"\t"+3+"\t"+3); // System.out.println(2+"\t"+5+"\t"+4); // System.out.println(3+"\t"+4+"\t"+5); // System.out.println(4+"\t"+3+"\t"+6); int sum=0; for (int i = 0; i <5 ; i++) { for (int j = 0; j <5 ; j++) { if (array[i][j]!=0){ sum++; } } } int[][] arr2=new int[sum+1][3]; //这个二维数组的第一行是确定的 arr2[0][0]=5; arr2[0][1]=5; arr2[0][2]=sum; int count=0; for (int i = 0; i < array.length; i++) { for (int j = 0; j < array[i].length; j++) { if (array[i][j]!=0){ count++; arr2[count][0]=i; arr2[count][1]=j; arr2[count][2]=array[i][j]; } } } System.out.println("输出稀疏数组"); for (int[] ints : arr2) { for (int anInt : ints) { System.out.print(anInt+" "); } System.out.println(); } } }
출력:
원래 배열을 출력합니다.
0 0 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 2 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
유효 값 개수: 2
출력 희소 배열:
11 11 2
1 2 1
3 2 2
=========나누기=========잘라내기==========선=============
우리는 나눌 수도 있습니다. 희소 배열에서 축소를 수행합니다
축소된 배열을 인쇄합니다
0 0 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 2 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
위 내용은 Java에서 희소 배열에 대한 코드를 작성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!