目录
1.为什么需要数组?
2.数组的介绍
3.数组的快速入门
4.数组的使用
5.动态初始化
6.静态初始化
7.数组的细节
8.数组的赋值机制
9.数组拷贝
10.数组反转
11.二维数组
12.冒泡排序
1.为什么需要数组?
有五个学生,他们英语成绩分别为60,70,90,80,50.用程序求几个同学总成绩是多少,平均分多少?
常规写法:定义五个变量,加起来就是总成绩,除以5就是平均成绩。这样定义很多变量是的程序非常繁琐。我们可以用数组来实现这个问题。
2.数组的介绍
数组可以存放多个同一类型的数据。数组也是一种数据类型,它是引用数据类型。
3.数组的快速入门
我们通过代码实现上面五个学生的问题:
public class Array01{
   public static void main(String[] args){
        //有五个学生,他们英语成绩分别为60,70,90,80,50用程序求几个同学总成绩是多少,平均分多少?
        //传统方式:
        double s1 = 60;
        double s2 = 70;
        double s3 = 90;
        double s4 = 80;
        double s5 = 50;
        double sum = s1 + s2 + s3 + s4 + s5;
        double avg = sum / 5;
        System.out.println("总成绩为:"+ sum + ", 平均成绩为:"+ avg); 
        //以上这种方式难免有些繁琐了,我们使用数组可以很简单的解决这个问题。
        //1.定义一个double类型的数组,把成绩存到数组中
        double[] arrays = {60,70,90,80,50};
        //2.数组是从0开始,所以下标为arrays[0]就是第一个数;第二个数就是arrays[1],以此类推...
        //3.通过for循环可以访问数组的5个元素值
        double sum2 = 0;
        for(int i = 0 ; i < arrays.length ; i++){
            sum2 += arrays[i];
        }
        System.out.println("总成绩为:"+ sum2 + ", 平均成绩为:"+ sum2/arrays.length); 
    }
}4.数组的使用
- 数组的定义:
 数据类型 数组名[] = new 数据类型[大小] 如:int a[] = new int[10]
 创建了一个数组,名字为a,可以存放10个数,就是a[0]到a[9]。超过10个会报错! 
- 数组的引用
 数组名[下标/访问/数组元素] 你要使用a数组的数字3,那么就是a[2],数组下标从0开始
5.动态初始化
- 声明数组:
语法:数据类型 数组名[] 或者 数据类型[] 数组名;例如:int[] a;
- 创建数组:
语法:数组名 = new 数据类型[大小] 例如:a = new int[10];
6.静态初始化
- 初始化数组:
 语法:数据类型 数组名[] = {元素1,元素2,... ,元素n};
 例如:int[] a = {11,22,33,44,55,66};
7.数组的细节
- 数组是多个乡同类型数据的组合,实现对这些数据的统一管理。
- 数组中的元素可以是任何数据类型,包括基本数据类型和引用数据类型,但是不能混用。
- 数组创建后若没有赋值,不同的数据类型都有默认值
 byte 0, short 0 , int 0 , long 0,float 0.0, double 0.0,char \u0000,boolean false,String null
- 数组的使用步骤:1.声明数组开辟空间 2.数组赋值 3.使用
- 数组下标都是从0开始
- 数组下标必须在指定范围内,超过范围报错(数组下标越界异常)
8.数组的赋值机制
- 基本数据类型赋值,这个值就是具体的数据,互不影响
- 数组默认情况引用传递,赋的是地址。 
9.数组拷贝
将int[] arr1 = {11,22,33};拷贝到arr2数组中。
public static void main(String[] args){
    //将int[] arr1 = {11,22,33};拷贝到arr2数组
    int[] arr1 = {11,22,33};
    int[] arr2 = new int[arr1.length];
    //把arr1的所有元素赋到arr2中
    for(int i = 0 ; i < arr1.length ; i++){
        arr2[i] = arr1[i];
    }
    //输出arr2查看
    for(int i = 0 ; i < arr2.length ; i++){
        System.out.println(arr2[i]);
    }
}10.数组反转
把数组中的数反转:arr{11,22,33,44,55,66,77} arr{77,66,55,44,33,22,11}
逆序赋值的方式:
public class arr{
    public static void main(String[] args){
        int[] arr = {11,22,33,44,55,66,77};
        //创建一个空的且同等大小的数组
        int[] arr2 = new int[arr.length];
        //逆序遍历
        for(int i = arr.length-1,j = 0;i>=0;i--,j++{
            arr2[j] = arr[i];
        } 
    }
}11.二维数组
-  动态初始化 
 语法:类型[][] 数组名 = new 类型[大小][大小] 如:int a[][] = new int[3][3];
-  二维数组在内存的形式: 
-  动态初始化 
 类型 数组名[][] = new 类型[大小][大小];
-  静态初始化 
 类型 数组名[][] = {{1,1},{2,2},{1,2}};
-  使用细节 -  二维数组的声明方式:int[][] a ,int[] a[] ,int a[][] 
-  二维数组实际上是多个数组组成的 
 
-  
12.冒泡排序
思想:通过排序从后向前依次比较相邻元素的值,若发现逆序则交换,使值较大的往后移。像气泡一样逐渐向上浮。
举例说明:我们将五个无序的:33,22,55,11,44使用冒泡排序将其排成从小到大有序的数列
public class BubbleSort {
    public static void main(String[] args) {
        int[] arr = {33, 22, 55, 11, 44};
        int temp;
        for (int i = 0; i < arr.length - 1; i++) {
            for (int j = 0; j < arr.length - i - 1; j++) {
                if (arr[j] > arr[j + 1]) {
                    temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
        }
        System.out.println("从小到大排序后的数组为:");
        for (int num : arr) {
            System.out.print(num + " ");
        }
    }
}













![[n00bzCTF 2023] CPR 全](https://img-blog.csdnimg.cn/9984f416418e43e7837cde50f299679b.png)





