乐趣区

关于后端:Java数组

1. 数组

概念:

​ 指的是一种容器,能够同来存储同种数据类型的多个值。

​ 然而数组容器在存储数据的时候,须要联合隐式转换思考。

比方:

​ 定义了一个 int 类型的数组。那么 boolean。double 类型的数据是不能存到这个数组中的,

​ 然而 byte 类型,short 类型,int 类型的数据是能够存到这个数组外面的。

倡议:

​ 容器的类,和存储的数据类型保持一致。

举例:

​ 整数 1 2 3 4 56 就能够应用 int 类型的数组来存储。

​ 小数 1.1 1.2 1.3 1.4 就能够应用 double 类型的数组来存储。

​ 字符串 ”aaa” “bbb” “ccc” 就能够应用 String 类型的数组来存储。

2. 数组的定义

格局一:

​ 数据类型 [] 数组名

比方:int [] array

格局二:

​ 数据类型 数组名 []

比方:int array []

详解:

数据类型:限定了数组当前能存什么类型的数据。

方括号:示意当初定义的是一个数组。

数组名:就是一个名字而已,不便当前应用。

留神点:

​ 办法括号跟数组名,谁写在后面,谁写在前面都是一样的。

​ 平时习惯性应用第一种形式。

3. 数组的动态初始化

残缺格局:

​ 数据类型 [] 数组名 = new 数据类型 []{元素 1,元素 2,元素 3,元素 4 …};

比方:

​ int[] arr = new int[]{11,22,33};

​ double[] arr = new double[]{1.1,1.2,1.3};

格局详解:

​ 数据类型:限定了数组当前能存什么类型的数据。

​ 方括号:示意当初定义的是一个数组。

​ 数组名:其实就是名字而已,不便当前应用,在起名字的时候遵循小驼峰命名法。

​ arr namesArr

​ new:就是给数组在内存中开拓了一个空间。

​ 数据类型:限定了数组当前能存什么类型的数据。

​ 后面和前面的数据类型肯定要保持一致。

​ int[] arr = new double[]{11,22,33};// 谬误写法

​ 方括号:示意当初定义的是一个数组。

​ 大括号:示意数组外面的元素。元素也就是存入到数组中的数据。

​ 多个元素之间,肯定要用逗号隔开。

留神点:

  • 等号前后的数据类型必须保持一致。
  • 数组一旦创立之后,长度不能发生变化。

简化格局:

​ 数据类型 [] 数组名 = { 元素 1,元素 2,元素 3,元素 4 …};

比方:

​ int[] array = {1,2,3,4,5};

​ double[] array = {1.1,1.2,1.3};

练习 1:

定义数组存储 5 个学生的年龄。

1. 给数组限定什么类型?int
2. 利用动态初始化实现创立并增加元素
int[] agesArr = new int[]{18,19,20,21,22};
int[] agesArr = {18,19,20,21,22};

练习 2:

定义数组存储 3 个学生的姓名。

1. 给数组限定什么类型?String
2. 利用动态初始化实现创立并增加元素
String[] namesArr = new String[]{"zhangsan","lisi","wangwu"};
String[] namesArr = {"zhangsan","lisi","wangwu"};

练习 3:

定义数组存储 4 个学生的身高。

1. 给数组限定什么类型?double
2. 利用动态初始化实现创立并增加元素
double[] heightsArr = new double[]{1.85,1.82,1.78,1.65};
double[] heightsArr = {1.85,1.82,1.78,1.65};

4. 地址值

int[] arr = {1,2,3,4,5};
System.out.println(arr);//[I@6d03e736

double[] arr2 = {1.1,2.2,3.3};
System.out.println(arr2);//[D@568db2f2

打印数组的时候,理论呈现的是数组的地址值。

数组的地址值:就示意数组在内存中的地位。

以 [I@6d03e736 为例:

[:示意当初打印的是一个数组。

I:示意当初打印的数组是 int 类型的。

@:仅仅是一个距离符号而已。

6d03e736:就是数组在内存中真正的地址值。(十六进制的)

然而,咱们习惯性会把 [I@6d03e736 这个整体称之为数组的地址值。

地址值对于咱们来京,作用不大,简略理解。

5. 数组元素拜访

格局:

​ 数组名 [索引];

作用:

  • 获取数组中对应索引上的值
  • 批改数组中对应索引上的值

    一旦批改之后,原来的值就会被笼罩了。

代码示例:

public class ArrDemo2 {
    /*

        数组中元素拜访的格局:数组名 [索引];

         作用:1. 获取指定索引上对应的元素
            2. 批改指定索引上对应的元素


    */
    public static void main(String[] args) {int[] arr = {1,2,3,4,5};
       // 需要 1:获取 arr 数组中,3 索引上的值
        int number = arr[3];
        System.out.println(number);
        System.out.println(arr[3]);

       // 需要 2:将 arr 数组中,3 索引上的值批改为 10
            arr[3] = 10;
        System.out.println("批改之后为:" + arr[3]);

    }
}

6. 索引

​ 也叫角标、下标

​ 就是数组容器中每一个小格子对应的编号。

索引的特点:

  • 索引肯定是从 0 开始的。
  • 间断不间断。
  • 一一 + 1 增长。

7. 数组的遍历

遍历:就是把数组外面所有的内容一个一个全副取出来。

数组的长度:数组名.length;

通用代码:

for(int i = 0; i < arr.length; i++){
    // 在循环的过程中,i 顺次示意数组中的每一个索引
    sout(arr[i]);// 就能够把数组外面的每一个元素都获取进去,并打印在管制台上了。}

8. 数组的动静初始化

格局:

​ 数据类型 [] 数组名 = new 数据类型 [ 数组的长度];

举例:

//1. 定义一个数组,存 3 集体的年龄,年龄未知
int[] agesArr = new int[3];


//2. 定义一个数组,存班级 10 名学生的考试成绩,考试成绩临时未知,考完才晓得。int[] scoresArr = new int[10];

数组的默认初始化值:

整数类型:0

小数类型:0.0

布尔类型:false

字符类型:’\u0000′

援用类型:null

9. 数组两种初始化形式的区别

动态初始化:int[] arr = {1,2,3,4,5};

动静初始化:int[] arr = new int[3];

动态初始化:手动指定数组的元素,零碎会依据元素的个数,计算出数组的长度。

动静初始化:手动指定数组长度,由零碎给出默认初始化值。

应用场景:

只明确元素个数,然而不明确具体的数据,举荐应用动静初始化。

曾经明确了要操作的所有数据,举荐应用动态初始化。

举例:

  • 应用数组来存储键盘录入的 5 个整数。

    int[] arr = new int[5];

  • 将全班的学生问题存入数组中,已知学生问题为:66,77,88,99,100

    int[] arr = new int[5];

    arr[0] = 66;

    arr[1] = 77;

    … 尽管能够实现,然而太麻烦了。

    倡议应用动态初始化:int[] arr = {66,77,88,99,100};

10. 数组常见问题

当拜访了数组中不存在的索引,就会引发索引越界异样。

防止:

​ 针对于任意一个数组,索引的范畴:

   最小索引:0
   最大索引:数组的长度 - 1

​ 数组名.length – 1

public class ArrDemo6 {public static void main(String[] args) {int[] arr = {1,2,3,4,5,5,5,5,5};
        // 用索引来拜访数组中的元素
        System.out.println(arr[1]);
        System.out.println(arr[10]);//ArrayIndexOutOfBoundsException

    }
}

11. 数组的练习

练习 1:求和

需要:定义一个数组,存储 1,2,3,4,5

遍历数组失去每一个元素,求数组外面所有的数据和

代码示例:

/* 定义一个数组,存储 1,2,3,4,5
        遍历数组失去每一个元素,求数组外面所有的数据和 */


// 剖析://1. 定义一个数组,并增加数据 1,2,3,4,5
int[] arr = {1,2,3,4,5};

// 求和变量
int sum = 0;
//2. 遍历数组失去每一个数据,累加求和
for (int i = 0; i < arr.length; i++) {
    //i 顺次示意数组外面的每一个索引
    //arr[i] 顺次示意数组外面的每一个元素
    sum = sum + arr[i];
}

// 当循环完结之后,sum 的值就是累加之后的后果
System.out.println(sum);

练习 2:统计个数

需要:定义一个数组,存储 1,2,3,4,5,6,7,8,9,10

遍历数组失去每一个元素,统计数组外面一共有多少个能被 3 整除的数字

代码示例:

// 剖析://1. 定义一个数组 存储 1,2,3,4,5,6,7,8,9,10
int[] arr = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
// 定义一个变量,用来统计次数
int count = 0;
//2. 遍历数组失去每一个元素
for (int i = 0; i < arr.length; i++) {
    //i 示意数组外面的每一个索引
    //arr[i] 示意数组外面的每一个元素
    //3. 判断以后的元素是否为 3 的倍数,如果是那么统计变量就须要自增一次。if(arr[i] % 3 == 0){// System.out.println(arr[i]);
        count++;
    }
}
// 当循环完结之后,就示意数组外面所有的数字都判断结束了,间接打印 count 即可
System.out.println("数组中能被 3 整除的数字有" + count + "个");

练习 3:变动数据

需要:

定义一个数组,存储 1,2,3,4,5,6,7,8,9,10

遍历数组失去每一个元素。

要求:

1,如果是奇数,则将以后数字扩充两倍

2,如果是偶数,则将以后数字变成二分之一

代码示例:

// 剖析://1. 定义一个数组,存 1,2,3,4,5,6,7,8,9,10
int[] arr = {1,2,3,4,5,6,7,8,9,10};
//2. 遍历数组失去每一个元素
for (int i = 0; i < arr.length; i++) {
    //i 顺次示意数组外面的每一个索引
    //arr[i] 顺次示意数组外面的每一个元素
    //3. 对每一个元素进行判断
    if(arr[i] % 2 == 0){
        // 偶数 变成二分之一
        arr[i] = arr[i] / 2;
    }else{
        // 奇数 扩充两倍
        arr[i] = arr[i] * 2;
    }
}

// 遍历数组
// 一个循环尽量只做一件事件。for (int i = 0; i < arr.length; i++) {System.out.println(arr[i]);
}

练习 4:求最值

需要:求数组中的最大值

代码示例:

// 定义数组求最大值:33,5,22,44,55

// 扩大问题://1. 依据求最大值的思路,本人改写一下求最小智
//2. 为什么 max 要记录为 arr[0], 默认值不能为 0 吗?// 不能写 0
//max 的初始化值肯定要是数组中的值。//3. 循环中开始条件肯定是 0 吗?// 循环的开始条件如果为 0,那么第一次循环的时候是本人跟本人比了一下,对后果没有任何影响,然而效率偏低
// 为了提高效率,缩小一次循环的次数,循环开始条件能够写 1.


//1. 定义数组用来存储 5 个值
int[] arr = {33,5,22,44,55};
//2. 定义一个变量 max 用来存储最大值
// 长期认为 0 索引的数据是最大的
int max = arr[0];
//3. 循环获取数组中的每一个元素
// 拿着每一个元素跟 max 进行比拟
for (int i = 1; i < arr.length; i++) {//i 索引  arr[i] 元素
    if(arr[i] > max){max = arr[i];
    }
}
//4. 当循环完结之后,max 记录的就是数组中的最大值
System.out.println(max);//55

练习 5:统计个数

需要:生成 10 个 1~100 之间的随机数存入数组。

1)求出所有数据的和

2)求所有数据的平均数

3)统计有多少个数据比平均值小

代码示例:

// 剖析://1. 定义数组
int[] arr = new int[10];
//2. 把随机数存入到数组当中
Random r = new Random();

for (int i = 0; i < arr.length; i++) {
    // 每循环一次,就会生成一个新的随机数
    int number = r.nextInt(100) + 1;
    // 把生成的随机数增加的数组当中
    // 数组名 [索引] = 数据;
    arr[i] = number;
}


// 1)求出所有数据的和
// 定义求和变量
int sum = 0;
for (int i = 0; i < arr.length; i++) {
    // 循环失去每一个元素
    // 并把元素累加到 sum 当中
    sum = sum + arr[i];
}
System.out.println("数组中所有数据的和为:" + sum);


//2)求所有数据的平均数
int avg = sum / arr.length;
System.out.println("数组中平均数为:" + avg);



//3)统计有多少个数据比平均值小
int count = 0;
for (int i = 0; i < arr.length; i++) {if(arr[i] < avg){count++;}
}

// 当循环完结之后,就示意我曾经找到了所有的比平均数小的数据
System.out.println("在数组中,一共有" + count + "个数据,比平均数小");



// 遍历数组,验证答案
for (int i = 0; i < arr.length; i++) {System.out.print(arr[i] + " ");
}

练习 6:替换数据

需要:定义一个数组,存入 1,2,3,4,5。依照要求替换索引对应的元素。

替换前:1,2,3,4,5

替换后:5,2,3,4,1

代码示例:

//1. 定义数组存储数据
int[] arr = {1,2,3,4,5};
//2. 利用循环去替换数据
for(int i = 0,j = arr.length - 1; i < j; i++,j--){
    // 替换变量 i 和变量 j 指向的元素
    int temp = arr[i];
    arr[i] = arr[j];
    arr[j] = temp;
}
// 当循环完结之后,那么数组中的数据就实现了头尾替换
for (int i = 0; i < arr.length; i++) {System.out.print(arr[i] + " ");
}

练习 7:打乱数据

需要:定义一个数组,存入 1~5。要求打乱数组中所有数据的程序。

代码示例:

//1. 定义数组存储 1~5
int[] arr = {1, 2, 3, 4, 5};
//2. 循环遍历数组,从 0 索引开始打乱数据的程序
Random r = new Random();
for (int i = 0; i < arr.length; i++) {
    // 生成一个随机索引
    int randomIndex = r.nextInt(arr.length);
    // 拿着随机索引指向的元素 跟 i 指向的元素进行替换
    int temp = arr[i];
    arr[i] = arr[randomIndex];
    arr[randomIndex] = temp;
}
// 当循环完结之后,那么数组中所有的数据曾经打乱程序了
for (int i = 0; i < arr.length; i++) {System.out.print(arr[i] + " ");
}
退出移动版