Java基础--数组

tech2024-10-08  27

数组概述

数组是相同类型数据的有序集合。 数组 描述的是相同类型的若干数据,按照一定的先后次序排列组合而成。 数组中的每一个数据称为一个元素,通过下标访问数组。

数组创建

package array; public class Demo01 { public static void main(String[] args) { int[] numbers; //1.声明一个数组 numbers = new int[10]; //2.分配空间 //3. 赋值 numbers[0] = 1; numbers[1] = 2; numbers[2] = 3; numbers[3] = 4; numbers[4] = 5; numbers[5] = 6; numbers[6] = 7; numbers[7] = 8; numbers[8] = 9; numbers[9] = 10; System.out.println(numbers[2]); int sum = 0; for (int i = 0; i <numbers.length ; i++) { sum += numbers[i]; } System.out.println("总和为:" + sum); } }

package array; public class Demo02 { public static void main(String[] args) { // 静态初始化 int[] a = {1,2,3,4,5}; Man[] man = {new Man(),new Man()}; //动态初始化 int[] b = new int[10]; b[0] = 10; System.out.println(b[0]); System.out.println(b[1]); } }

数组使用

package array; import java.sql.PreparedStatement; public class Demo03 { public static void main(String[] args) { int[] array = {1,2,3,4,5}; //遍历 for (int i = 0; i < array.length ; i++) { System.out.println(array[i]); } //求和 int sum = 0; for (int i = 0; i < array.length ; i++) { sum += array[i]; } System.out.println(sum); //找最大数 int max = array[0]; for (int i = 0; i <array.length ; i++) { if(array[i] > max){ max = array[i]; } } System.out.println(max); //for each for (int arr:array ) { System.out.println(arr); } //反转数组 int[] result = new int[array.length]; for (int i = 0, j = array.length-1; i < array.length; i++,j--) { result[i] = array[j]; } for (int res:result ) { System.out.println(res); } } }

多维数组

package array; public class Demo04 { public static void main(String[] args) { int[][] arrays = {{1,2,3},{4,5,6}}; for (int i = 0; i < 2 ; i++) { for (int j = 0; j <arrays[0].length ; j++) { System.out.println(arrays[i][j]); } } } }

Arrays类

package array; import java.util.Arrays; public class ArraysDemo { public static void main(String[] args) { int[] a = {1,2,5,3,343,56,43,45454}; System.out.println(Arrays.toString(a)); Arrays.sort(a); //排序,升序 System.out.println(Arrays.toString(a)); Arrays.fill(a,0); //填充 //Arrays.fill(a,2,3,4); System.out.println(Arrays.toString(a)); } public static void PrintArray(int[] a){ for (int i = 0; i <a.length ; i++) { if (i == 0) { System.out.print("["); } if (i == a.length - 1) { System.out.print(a[i] + "]"); } else { System.out.print(a[i] + ", "); } } } }

冒泡排序

package array; import java.util.Arrays; public class BubbleSort { public static void main(String[] args) { int[] a = {1,3,2,4,9,6,5,7,8}; System.out.println(Arrays.toString(a)); int[] sort = bubleSort(a); System.out.println(Arrays.toString(sort)); } public static int[] bubleSort(int[] a){ for (int i = 0; i <a.length-1 ; i++) { boolean flag = false; for (int j = 0; j <a.length-1-i; j++) { if(a[j]>a[j+1]){ int t = a[j]; a[j] = a[j+1]; a[j+1] = t; flag = true; } } if(flag==false){ break; } } return a; } }

稀疏数组

package array; import java.util.Arrays; //稀疏数组 public class xisushuzu { public static void main(String[] args) { int[][] a = new int[11][11]; a[1][2] = 1; a[2][3] =2; System.out.println("原始数组:"); for (int[] arr:a) { for (int ar:arr) { System.out.print(ar+"\t"); } System.out.println(); } int count=0; for (int i = 0; i < a.length ; i++) { for (int j = 0; j <a[i].length; j++) { if(a[i][j]!=0){ count++; } } } int[][] xisu = new int[count+1][3]; xisu[0][0] = a.length; xisu[0][1] = a[0].length; xisu[0][2] = count; int k = 1; for (int i = 0; i < a.length ; i++) { for (int j = 0; j <a[i].length; j++) { if(a[i][j]!=0){ xisu[k][0] = i; xisu[k][1] = j; xisu[k][2] = a[i][j]; k++; } } } System.out.println("稀疏数组:"); for (int i = 0; i <= count ; i++) { System.out.println(Arrays.toString(xisu[i])); } //稀疏数组还原 //1. 读取稀疏数组的值 int[][] arrr = new int[xisu[0][0]][xisu[0][1]]; for (int i = 1; i <xisu.length ; i++) { arrr[xisu[i][0]][xisu[i][1]] = xisu[i][2]; } System.out.println("还原数组:"); for (int[] br:arrr) { for (int b:br) { System.out.print(b+"\t"); } System.out.println(); } } }

<br /

最新回复(0)