dataType[] arrayRefVar;//首选的方法 或 dataType arrayRefVar[];//效果相同,但不是首选方法
dataType[] arrayFefVar = new dataType[arraySize];
public class ArrayDemo01 { //数组是相同类型数据的有序集合 //创建一个有10个元素的数组,不用去创建10个变量了 public static void main(String[] args) { //变量类型 变量名字 变量的值; int[] nums; //首选的数组声明方法 // int nums2[]; //C、C++风格的数组声明方法 nums = new int[10]; //创建一个数组 这里面可以存放10个int类型的数字 // int[] nums = new int[10]; //把前面的声明和创建合成一个步骤 nums[2]=100; //给数组元素赋值 未赋值的元素 int类默认为0 String默认为null for (int i = 0; i < nums.length; i++) { System.out.println(nums[i]); } } }
三种初始化:
int[] a = {1,2,3}; Man[] mans = {new Man(1,1),new Man(2,3)};
int[] a = new int[2]; a[0] = 1; a[1] = 2;
public class ArrayDemo02 { public static void main(String[] args) { //静态初始化 int[] a={1,2,3,4,5,6,7,8}; System.out.println(a[0]); //动态初始化 int[] b = new int[4]; b[0]=10; System.out.println(b[0]); } }
数组的四个基本特点:
public class ArrayDemo03 { public static void main(String[] args) { int[] arrays = {1,2,3,4,5}; //打印全部的数组元素 for (int i = 0; i < 5; i++) { System.out.println(arrays[i]); } System.out.println("======"); //求和 int sum = 0; for (int i = 0; i < 5; i++) { sum += arrays[i]; } System.out.println("sum:"+sum); System.out.println("======"); //找出最大值 int max = arrays[0]; for (int i = 0; i < 5; i++) { if(arrays[i]>max){ max = arrays[i]; } } System.out.println("max:"+max); } }
数组作为参数 或 数组作为返回值
public class ArrayDemo04 { public static void main(String[] args) { int[] arrays = {1,2,3,4,5}; // //JDK1.5 没有下标 小技巧arrays.for // for (int array : arrays) { // System.out.println(array); // } printArray(arrays); System.out.println(); int[] reverse = reverseArray(arrays); printArray(reverse); } public static void printArray(int[] arrs){ //打印数组元素 for (int i = 0; i < arrs.length; i++) { System.out.print(arrs[i]+" "); } } public static int[] reverseArray(int[] arrs){ int[] arrs2 = new int[arrs.length]; for (int j = 0; j < arrs.length; j++) { arrs2[j]=arrs[arrs.length-1-j]; } return arrs2; } }
打印二维数组
public class ArrayDemo05 { public static void main(String[] args) { //int[4][2] int[][] nums = {{1,2},{2,3},{3,4},{4,5}}; //打印二维数组 for (int i = 0; i < nums.length; i++) { for (int j = 0; j < nums[i].length; j++) { System.out.print(nums[i][j]+"\t"); } System.out.println(); } } }
import java.util.Arrays; public class ArrayDemo06 { public static void main(String[] args) { int[] a = {1,2,9,3,22,15,888,655}; // System.out.println(a);//打印出来的是数组a的hashcode // System.out.println(Arrays.toString(a));//打印数组元素 // arrayPrint(a);//我们自己造轮子写的一个轮子 Arrays.sort(a);//升序排序,利用这个工具类方法后,数组a已经改变! System.out.println(Arrays.toString(a)); } public static void arrayPrint(int[] arrays){ System.out.println("["); for (int i = 0; i < arrays.length; i++) { if (i==arrays.length-1){ System.out.print(arrays[i]+"]"); }else { System.out.print(arrays[i]+", "); } } } }
import java.util.Arrays; public class ArrayDemo07 { public static void main(String[] args) { int[] arrays = {2,1,5,1,10,8,7}; int[] b = bubble(arrays); System.out.println(Arrays.toString(b)); } //冒泡排序 //1.比较数组中两个相邻的元素,如果第一个数比第二个数大,我们就交换它们的位置 //2.每一轮比较,都会产生出一个最大或者最小的数字(从左往右比较,产生一个最大值;如果从右往左比较,产生一个最小值) //3.下一轮则可以少一次比较 //依次循环,直到结束 public static int[] bubble(int[] a){ if(a.length>=2) { for (int j = 0; j < a.length-1; j++) { for (int i = 0; i < a.length-1-j; i++) { int max = 0; if(a[i]>a[i+1]){ max = a[i]; a[i] = a[i+1]; a[i+1] = max; } } } } return a; } }