数组的定义
数组是相同类型数据的有序集合
数组描述的是相同类型的若干个数据,按照一定先后次序组合而成
其中,每一个数据称作一个数组元素,每个数组元素可以通过一个下标来访问它们,下标从0开始
例子:一个球队中的不同号码的队员
代码
public static void main(String[] args) {
int[] nums={10,20,30,40,50};
for(int i=0;i<5;i++)
{
System.out.println("这是第"+(i+1)+"个元素,其下标为:"+i);
}
}
数组的边界问题
合法的下标区间为[0 — length-1],越界就会报错
public static void main(String[] args) {
int[] nums = new int[10];
System.out.println(nums[11]);
}
会报异常:ArrayIndexOutOfBoundsException
数组下标越界
dataType[] arrayname;//首选方法,java风格
//或者
dataType arrayname[];//效果相同,但是非首选。c/c++风格
dataType[] arrayname = new dataType[arraySize];
arrays.length();
小例子
public static void main(String[] args) {
//声明数组
int[] nums;
//开辟空间
nums =new int[5];
for(int i=0;i<5;i++)
{
nums[i]=i;//给数组元素赋值
}
for(int i=0;i<5;i++)
{
System.out.println("这是第"+(i+1)+"个元素,值为"+nums[i]+",其下标为:"+i);
}
//计算数组的和
int i;
int sum=0;
//nums.length可以获取数组的长度
for (i = 1; i<=nums.length; i++)
{
sum += nums[i-1];
}
System.out.println("数组的和为:"+sum);
}
Java内存
声明数组时,在栈中注册array
开辟空间时,(new关键字),在堆中开辟空间
//声明创建以及赋值一起做
int a[]={0,1,2,3,4,5};
int[] a={0,1,2,3,4,5};
//声明创建空间一起做,默认初始值为0,需要手动赋值
int a[]=new int[5];
a[2]=10;
数组为引用类型,它的元素相当于类的实例变量,因此一经分配空间,就会被隐式初始化
//一经初始化,a[0]到a[4]的值都会被初始化为0
int a[]=new int[5];
代码
public static void main(String[] args) {
int a[]={1,2,3,4,5};
for (int x : a) {
System.out.println(x);
}
}
数组也可以用作方法的参数以及返回值
小例子
public static void main(String[] args) {
int a[]={1,2,3,4,5};
printArrays(reverse(a));
}
//反转数组
public static int[] reverse(int[] Arrays)
{
int a[]=new int[Arrays.length];
for(int c=0;c<Arrays.length;c++){
a[Arrays.length-1-c]=Arrays[c];
}
return a;
}
//输出数组元素
public static void printArrays(int[] Arrays)
{
for (int x : Arrays) {
System.out.print(x+" ");
}
}
这里提一嘴,数组入参,是引用传参,如果在函数中修改数组的值,会直接将原数组的数修改
以二维数组为例:二维数组可以理解为一维数组的每一个元素都是一个数组
//一个两行五列的数组
int[][] a = new int[2][5];
小例子
public static void main(String[] args) {
int[][] a={{1,2},{2,3},{3,4}};
/*
实际情况
a[0][0],a[0][1]中存储的是 1,2
2,3
3,4
*/
//输出数组元素
System.out.println(a[0][1]);
//函数输出二维数组的值
printArrays(a);
}
//输出数组元素
public static void printArrays(int[][] Arrays)
{
for (int[] x : Arrays) {
for (int a : x) {
System.out.print(a+" ");
}
System.out.println();
}
}
java.util中的Arrays类
Arrays类中实现了好多方法,Arrays类被用static修饰,因此调用该类的方法需要直接使用类名进行调用
public static void main(String[] args) {
int a[]={10,2,55,85,45,78};
int a2[]={10,2,55,85,45,78};
//对数组进行排序,升序
Arrays.sort(a);
System.out.println(Arrays.toString(a));
//用fill对数组进行赋值
Arrays.fill(a,0);
//fill方法重载
Arrays.fill(a,1,3,9);
System.out.println(Arrays.toString(a));
//equals方法的使用
if(Arrays.equals(a,a2)){
System.out.println("这两个数组一样");
}
else{
System.out.println("这两个数组不一样");
}
//binarySearch方法来查找数字
//首先需要排好序
Arrays.sort(a2);
System.out.println("这里输出的是待查找数字的下标:"+Arrays.binarySearch(a2,45));
}
思想类似泡泡从水底产生,不断地浮上水面,浮到水面变成最大的
双层嵌套循环,时间复杂度:O(n^2)
public static void main(String[] args) {
//冒泡排序演示
int []a={12,55,89,57,15,21,3,78,6};
System.out.println(Arrays.toString(a));
bubble(a);
System.out.println(Arrays.toString(a));
}
//冒泡排序主函数
public static void bubble(int[] arrays){
int temp = 0;
int count = 0;
//每一趟都能找出一个当前未排好序元素中的最大
for(int i=0;i<arrays.length;i++)
{
//每趟排序后,需要排序的数字就少一个,不需要每一趟排序都到最后一个数
for (int j=0;j<arrays.length-1-i;j++)
{
//每趟比较相邻地两个元素,若下标小的大于下标大的,则交换位置
count++;
if(arrays[j]>arrays[j+1])
{
temp=arrays[j];
arrays[j]=arrays[j+1];
arrays[j+1]=temp;
}
}
}
System.out.println("比较次数:" + count);
}
需求提出,在五子棋或者围棋游戏中涉及到存档问题,可以使用数组进行存储,但是如果棋面上只有几颗棋,那么数组中存储的很多值都是0,可以说存储了许多没有意义的数据
稀疏数组
public static void main(String[] args) {
//创建二位数组11*11,0:没有棋子 1:黑棋 2:白棋
int[][] nums = new int[11][11];
nums[1][2] = 1;
nums[2][3] = 2;
System.out.println("输出原始数据");
for (int[] num : nums) {
System.out.println(Arrays.toString(num));
}
System.out.println("转换为稀疏数组");
//1.获取有效值的个数
int sum =0;
for (int i = 0; i < 11; i++) {
for (int j = 0; j < 11; j++) {
if (nums[i][j]!=0)
sum++;
}
}
System.out.println("有效值的个数为:" + sum);
//2.创建稀疏数组,行固定为有效值个数+1,列固定为3列
int[][] array = new int[sum + 1][3];
array[0][0] = 11;
array[0][1] = 11;
array[0][2] = sum;
//遍历二维数组,将非零元素,放入稀疏数组中
int count = 1;
for (int i = 0; i < nums.length; i++) {
for (int j = 0; j < nums[i].length; j++) {
if(nums[i][j] != 0)
{
array[count][0] =i;
array[count][1] =j;
array[count][2] =nums[i][j];
count++;
}
}
}
//输出稀疏数组
System.out.println("输出稀疏数组");
for (int[] ary : array) {
System.out.println(Arrays.toString(ary));
}
System.out.println("还原");
int[][] trans = new int[array[0][0]][array[0][1]];
for (int i = 1; i <= array[0][2]; i++) {
trans[array[i][0]][array[i][1]] =array[i][2];
}
System.out.println("输出还原后的数组");
for (int[] tra : trans) {
System.out.println(Arrays.toString(tra));
}
}