数组
为什么要使用数组?
学生成绩排序问题
如果没有数组,我们得定义30个变量。
数组是相同类型的数据按顺序组成的一种引用数据类型
要学习的内容:
一维数组: 声明 创建 初始化 元素的引用 长度 数组的应用
数组的概念
数组声明语法格式:
数据类型[] 数组名; 数据类型 数组名[]; //和c等一致的形式int[] myIntArray;int myIntArray[];char[] ch; String[] strArray;//字符串是一个类,这是对象数组。
变量声明的语法格式:
数据类型 变量名;
数据类型后加上了中括号。命名规范上第一个单词首字母小写,之后单词首字母大写。
数组的创建:
语法格式一:先声明后创建
数据类型[] 数组名; 数组名 = new 数据类型[数组长度]; // new是在创建一个对象,这里是创建一个数组int[] arr; arr= new int[10]; // 创建一个长度为10的整型数组
语法格式二:声明的同时创建数组
数据类型[] 数组名= new 数据类型[数组长度];int[] arr= new int[10]; // 创建长度为10的整型数组arr
注意:数组创建时长度必须指定
数组在内存中的存储
数组会被分配连续的内存空间
int[] a=new int[5];
默认值都为0。数组名是一个对象,指向数组中的第一个元素。
局部变量和数组的默认值问题: 局部变量是没有默认值的,如果没有初始化,是内存中的随机值。而数组是有默认值的0的,因为数组本身是对象。
数组的初始化: 声明数组的同时给数组赋值,叫做数组的初始化。
例子:
int[] arr={1,2,3,4,5,6,7,8,9,10};
数组的长度就是初始化时所给数组元素的个数
数组元素的引用
语法格式:
数组名[下标];
注意:下标从0开始
int[] arr={1,2,3,4,5,6,7,8,9,10};
连续的内存空间当中存储数组的值
变量名 和 变量值的关系
数组的长度:
int[] arr={1,2,3,4,5,6,7,8,9,10};// 属性length表示数组的长度,如a.length
一维数组的应用
package cn.mtianyan.array;public class ArrayDemo { public static void main(String[] args) { // 声明数组 int[] intArray; String strArray[]; // 创建数组 intArray = new int[5]; strArray = new String[10]; // 声明数组的同时进行创建 float[] floatArray = new float[4]; // 初始化数组 char[] ch = {'a','b','c','d'}; System.out.println("ch数组的长度为: "+ch.length); // 数组默认值 char[] charArray = new char[5]; System.out.println("intArray数组的第二个元素为: "+intArray[1]); System.out.println("strArray数组的第五个元素为: "+strArray[4]); System.out.println("floatArray的最后一个元素为:"+floatArray[floatArray.length-1]); System.out.println("charArray的第一个元素为: "+charArray[0]+"End"); } }
所有对象数组都像strArray一样在创建时默认值为null;使用循环对整型数组赋值。
// 循环为整型数组赋值 for (int i=0;i<5;i++){ intArray[i] = i+1; } System.out.println("整型数组intArray的元素为: "); for (int i=0;i<5;i++){ System.out.print(intArray[i]+" "); }
数组下标越界,会报出异常。ArrayIndexOutOfBoundsException(运行时异常) 数组下标越界异常。
求数组元素的累加和
定义一个整型数组,从键盘接收输入值,然后求累加和。
package cn.mtianyan.array;import java.util.Scanner;public class ArrayAddDemo { public static void main(String[] args) { int[] intArray = new int[5]; System.out.println("请输入五个数组的元素,输入0为计算前面几个输入值,只输入0退出程序:"); Scanner scanner = new Scanner(System.in); int sum=0; while (true) { sum = 0; for (int i = 0; i < 5; i++) { intArray[i] = scanner.nextInt(); if (intArray[i] == 0) break; sum = sum + intArray[i]; } if (sum==0) break; System.out.println("sum:" + sum); } } }
package cn.mtianyan.array;import java.util.Scanner;public class ArrayDemo1 { public static void main(String[] args) { int[] a = new int[5]; Scanner scanner = new Scanner(System.in); for (int i=0;i<a.length;i++){ System.out.print("请输入第"+(i+1)+"个元素: "); a[i] = scanner.nextInt(); } System.out.println(); System.out.println("数组元素的内容为: "); for (int i=0;i<a.length;i++){ System.out.print(a[i]+" "); } } }
int sum=0; for (int i=0;i<a.length;i++){ sum +=a[i]; } System.out.println("数组累加和为: "+sum);
编程练习
求数组中能被3整除的元素并打印输出。
效果图:
任务:
定义一个整型数组a并初始化
循环遍历数组,找出能被3整除的元素并打印输出
package cn.mtianyan.array;public class ArrayExercise { public static void main(String[] args) { int[] a ={1,2,6,12,15,16,17}; System.out.println("能被3整除的数组元素为:"); for (int i=0;i<a.length;i++){ if (a[i] % 3==0){ System.out.println(a[i]); } } } }
求数组元素的最大值
package cn.mtianyan.array;public class ArrayMaxDemo { public static void main(String[] args) { // 求数组元素最大值 int[] a ={1,2,6,12,35,16,17}; int max = 0; for (int i=0;i<a.length;i++){ if(a[i]>max){ max = a[i]; } } System.out.println("max:" +max); } }
优化: max 之间等于a[0] 然后循环就可以从1开始了,少了一次比较。
public static void main(String[] args) { // 求数组元素最大值 int[] a ={34,23,78,56,31}; int max = a[0]; for (int i=1;i<a.length;i++){ if(a[i]>max){ max = a[i]; } } System.out.println("max:" +max); }
增强型for循环
和数组结合起来使用会更加方便
又叫foreach循环, foreach循环应用:
System.out.println(); System.out.println("使用foreach输出数组内容:"); for (int n:a) { System.out.print(n+" "); }
如何对变量a,b的值进行交换
int a=3,b=5;int temp; temp=a;a=b;b=temp;
冒泡排序
对一组整数按照由小到大的顺序进行排序。
假设存放着这样一组整数,如何将它们从小到大进行排序。
对数组中元素从头到位对相邻的元素进行大小比较。
过程: 对34和53进行比较,发现34和53相比,53大的在右边是正常的,什么都不用做,12和53相比发现53是大的,53向上浮一位。53和32进行比较,53比32大,再次上浮。52和56比,很正常。然后56和17比,56上浮。
这就是冒泡排序.
package cn.mtianyan.array;public class SortDemo { public static void main(String[] args) { // 冒泡排序 int[] a ={34,53,12,32,56,17}; System.out.println("排序前的数组元素为: "); for (int n:a){ System.out.print(n+" "); } System.out.println(); int temp; // 外层控制趟,内层冒泡 for(int i=0;i<a.length-1;i++){ // 内层循环控制每趟排序,越到后边的趟,需要排的越少。 for (int j=0;j<a.length-1-i;j++){ // 前一个数大于后一个数,交换位置 if(a[j] > a[j+1]){ temp = a[j]; a[j] = a[j+1]; a[j+1] = temp; } } } System.out.println("从小到大排序排序后的数组元素为: "); for (int n:a) { System.out.print(n+" "); } } }
运行结果:
package cn.mtianyan.array;public class SortReverseDemo { public static void main(String[] args) { // 冒泡排序 int[] a ={34,53,12,32,56,17}; System.out.println("排序前的数组元素为: "); for (int n:a){ System.out.print(n+" "); } System.out.println(); for (int i=0;i<a.length-1;i++){ for (int j=0;j<a.length-1-i;j++){ if(a[j] < a[j+1]){ int temp = 0; temp = a[j]; a[j] = a[j+1]; a[j+1] = temp; } } } System.out.println("从大到小排序后的数组元素为: "); for (int n:a){ System.out.print(n+" "); } } }
运行结果:
作者:天涯明月笙
链接:https://www.jianshu.com/p/9cf0d5739056