Java第四章数组

Java第四章数组

一、数组

1、为什么需要数组

​ 数组是存储一组相同数据类型的数据(变量)的一个变量。
在这里插入图片描述

​ 声明一个变量就是在内存空间划出一块合适的空间

​ 声明一个数组就是在内存空间划出一串连续的空间

2、什么是数组

​ 数组基本要素:

​ ①标识符:也可以叫做数组名,类似于变量中的变量名。

​ ②数组元素:一个数组是由多个相同数据类型的数据组成的,里面每一个数据都是一个数组元素。

​ ③元素下标:从0开始(数组中的每个元素都有按排序进行编号,这个编号是从0开始,到数组长度-1为止,这种编号叫做元素下标。)

​ ④元素类型:我们在声明数组的时候,数组是什么数据类型,那数组里的所有元素就必须是和数组相同的数据类型。

​ ⑤数组长度:一个数组中一共有多少个数据,这个数组的数组长度就为多少。

在这里插入图片描述

二、使用数组

定义数组

​ 在程序中去定义一个数组,通常分为4个步骤:

​ 1、声明数组。

​ 声明数组的语法有两种格式,分别为:

​ 数据类型[] 数组名;

​ 或 数据类型 数组名[];

​ 两种格式都是可以使用的,但通常规范上提倡使用第一种,也就是 数据类型[] 数组名;

​ 例如:

​ int[] scores;

​ int scores[];

​ Srting[] names;

​ 2、分配空间。

​ 确定数组中一共有多少个数据,例如:

​ scores = new int[30];

​ avgAge= new int[6];

​ names= new String[30];

​ 分配完空间后,里面每个数据都会有个默认初始值。如果是整型的数组,里面所有元素初始值都为0;浮点型的数组,里面所有元素的初始值都为 0.0;如果是字符串类型的数组,里面所有元素的初始值都为null。

​ 声明数组和分配空间可以合在一步完成,语法格式为:

​ 数据类型[] 数组名 = new 数据类型[个数];

​ 例如:

​ int[] scores = new int[5];

​ 数组在内存空间中的表现:

在这里插入图片描述

​ 3、元素赋值。

​ (1)我们可以在声明数组的同时,给数组里的元素赋值。有两种格式,

​ 例如: int[] scores ={89,79,76};

​ int[] scores = new int[]{89,79,76};

​ 这两种边声明边赋值的语法作用是相同的。在列出数据的同时,也已经确定了这个数组的长度,后续是无法再增加数组个数的,并且在第二种语法 中,后面加了大括号和数值,大括号前面的中括号[]里就不能再写数组的长度了,否则就会报错。

​ (2)动态录入信息并赋值。这种方法用的比较多。可以通过循环的方式完成动态录入过程。

​ 例如:

			Scanner input = new Scanner(System.in);
			for(int i=0;i<=30;i++){
				scores[i] = input.nextInt();
			}

​ 4、处理数据。

​ 定义完数组后,就可以使用数组中的数据进行运算了。

​ 例如: a[0] = a[0] * 10;

​ 或者通过增强型for循环(foreach)来遍历数组,完成一些特定功能。

			for(int score : scores){
				sum += score;
			}
三、数组下标越界

​ 我们定义一个数组,他的元素下标是从0开始,到数组长度-1为止,在运用数组元素的时候,如果出现元素下标超出了数组元素下标范围的情况,程序就会报错,出现ArrayIndexOutOfBoundsException一长串的英文,表示的是数组的下标越界了。

​ 比如我们定义了一个长度为3的数组int[] scores = new int[3]

​ score[2] = 5;

​ score[3] = 8;

​ 这里score[3]就是一个数组下标越界的情况,这个数组中只有score[0]、score[1]、score[2]三个元素。

四、冒泡排序

​ 用二重循环实现冒泡排序
​ ①5个数字如何存放 ②控制比较多少轮 ③控制每轮比较多少次 ④交换数据

​ 冒泡排序口诀(升序)
​ ①N个数字来排队 ②两两相比小靠前 ③外层循环N-1 ④内层循环N-1-i

五、Arrays类

1、使用Arrays类为数组排序

①java.util包提供的工具类 ②Arrays与类提供组的方法 如:排序、查询 ③Arrays类的sort()方法:对数组进行升序排列

​ Arrays.sort(数组名);

2、Arrays类

方法名称说明
boolean equals(array1 , array2)比较array1和array2两个数 字是否相等
sort(array)对数组array的元素进行升序排列
String toString(array)将一个数组array转换成一个字符串
void fill (array,val)把数组array所有元素都赋值为val
copyOf(array , length)把数组array复制成一个长度为length 的新数组,返回类型与复制的数组一致
int binarySearch ( array , val )查询元素值val在数组 array 中的下标(要求数组中元素已经按升序排列)
六、二维数组

1、定义

​ <数据类型>[ ] [ ] 数据名;

​ 或者<数据类型>数组[ ] [ ];

			int [ ] [ ] scores; //定义二维数组
			scores = new int[ 5 ] [ 50 ];//分配内存空间
			//或者
			int[ ] [ ] scores = new int [ 5 ] [ 50 ]; 

2、定义二维数组时,要定义最大维数

           	int[ ]scores = new int[5][ ];

3、二维数组内存空间

int[  ] [  ] s =new int[3][5];

在这里插入图片描述

在这里插入图片描述

4、赋值

①int[ ][ ]scores = new int[ ][ ]{ {88,90,60,50,20} ,{90,80,60},{85} }
②int scores[ ][ ] = { {88,90,60,50,20} ,{90,80,60},{85} }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值