day05——数组

此资料是根据黑马程序员Java零基础视频教程提供的笔记进行修改而成,仅用于个人学习。

学习视频:https://www.bilibili.com/video/BV17F411T7Ao/?p=54&vd_source=a0fb36c5a191d7be68335738a8b342a2

1. 数组

1.1 概念

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

​ 但是数组容器在存储数据的时候,需要结合隐式转换考虑。


比如:

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

​ 但是byte类型,short类型,int类型的数据是可以存到这个数组里面的。


建议:

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


举例:

​ 整数1、2、3、4、5、6 就可以使用int类型的数组来存储。

​ 小数1.1 、1.2、 1.3、 1.4 就可以使用double类型的数组来存储。

​ 字符串"aaa" 、 “bbb” 、 “ccc” 就可以使用String类型的数组来存储。


2. 数组的定义

2.1 格式一(用的多)

数据类型[] 数组名

比如:int[] array

int[] array = new int[]{
    
    11,12,13,14,15};

2.2 格式二

数据类型 数组名[]

比如: int array[]

int array[] = new int[]{
    
    11,12,13,14,15};

2.3 详解

数据类型:限定了数组以后能存什么类型的数据。

方括号:表示现在定义的是一个数组。

数组名:就是一个名字而已,方便以后使用。


2.4 注意点

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

平时习惯性使用第一种方式。


3. 数组的静态初始化

3.1 完整格式

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

比如:

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

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

3.2 格式详解

(前面)数据类型:限定了数组以后能存什么类型的数据。

方括号:表示现在定义的是一个数组。

数组名:其实就是名字而已,方便以后使用,在起名字的时候遵循小驼峰命名法:arr namesArr

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

(后面)数据类型:限定了数组以后能存什么类型的数据。

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

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

方括号:表示现在定义的是一个数组。

大括号表示数组里面的元素。元素也就是存入到数组中的数据,多个元素之间,一定要用逗号隔开。


3.3 注意点

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

3.4 简化格式

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

比如:

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

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

3.4.1 练习1

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

1.给数组限定什么类型? int
2.利用静态初始化完成创建并添加元素
int[] agesArr = new int[]{
    
    18,19,20,21,22};
int[] agesArr = {
    
    18,19,20,21,22};

3.4.2 练习2

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

1.给数组限定什么类型? String
2.利用静态初始化完成创建并添加元素
String[] namesArr = new String[]{
    
    "zhangsan","lisi","wangwu"};
String[] namesArr = {
    
    "zhangsan","lisi","wangwu"};

3.4.3 练习3

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

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

打印数组的时候,实际出现的是数组的地址值

数组的地址值:就表示数组在内存中的位置


4.1 地址值解释

以[I@6d03e736为例:

[ :表示现在打印的是一个数组。

I:表示现在打印的数组是int类型的。 D:表示当前数组里面的元素都是double类型的。

@:仅仅是一个间隔符号而已。

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

但是,我们习惯性会把[I@6d03e736这个整体称之为数组的地址值

地址值对于我们来讲,作用不大,简单了解。


5. 数组元素访问

5.1 格式

数组名[索引];


5.2 作用

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

  • 修改数组中对应索引上的值

    一旦修改之后,原来的值就会被覆盖了

5.3 代码示例

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

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

    }
}

6. 索引

​ 也叫角标、下标

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


6.1 索引的特点

  • 索引一定是从0开始的。
  • 连续不间断
  • 逐个+1增长

7. 数组的遍历

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

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


通用代码:

        //1.定义数组
        int[] arr = {
    
    1,2,3,4,5};
        //2.获取数组里面所有的元素
        //格式: 数组名[索引]
        System.out.println(arr[0]);
        System.out.println(arr[1]);
        System.out.println(arr[2]);
        System.out.println(arr[3]);
        System.out.println(arr[4]);

------------------------------------------------------
        //利用循环改进代码
        //开始条件:0
        //结束条件:数组的长度 - 1(最大索引)
        for (int i = 0; i < 5; i++) {
    
    
            //i: 0 1 2 3 4
            System.out.println(arr[i]);
        }

------------------------------------------------------
        //在Java当中,关于数组的一个长度属性,length
        //调用方式:数组名.length
        //System.out.println(arr.length);
        for (int i = 0; i < arr.length; i++) {
    
    
            //i: 0 1 2 3 4
            System.out.println(arr[i]);
        }

------------------------------------------------------        
        //扩展:
        //自动的快速生成数组的遍历方式
        //idea提供的快捷操作:数组名.fori
        for (int i = 0; i < arr.length; i++) {
    
    
            System.out.println(arr[i]);
        }

idea提供的快捷操作:数组名.fori
在这里插入图片描述


8. 数组的动态初始化

8.1 格式

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


8.2 举例

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


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

8.3 数组的默认初始化值

整数类型:0

小数类型:0.0

布尔类型:false

字符类型:‘\u0000’

引用类型:null


案例:

        //数组默认初始化值的规律
        //整数类型:默认初始化值0
        //小数类型:默认初始化值0.0
        //字符类型:默认初始化值'\u0000' 空格
        //布尔类型:默认初始化值 false
        //引用数据类型:默认初始化值 null
        int[] intArray = new int[5];
        System.out.println("整数类型数组的默认初始化");
        for (int i = 0; i < intArray.length; i++) {
    
    
            if (i != intArray.length - 1) {
    
    
                System.out.print(intArray[i] + "  、");
            } else {
    
    
                System.out.println(intArray[i]);  //最后一个不需要顿号且换行
            }
        }

        double[] doubleArray = new double[5];
        System.out.println("小数类型数组的默认初始化");
        for (int i = 0; i < doubleArray.length; i++) {
    
    
            if (i != doubleArray.length - 1) {
    
    
                System.out.print(doubleArray[i] + "  、");
            } else {
    
    
                System.out.println(doubleArray[i]);  //最后一个不需要顿号且换行
            }
        }

        boolean[] booleanArray = new boolean[5];
        System.out.println("布尔类型数组的默认初始化");
        for (int i = 0; i < booleanArray.length; i++) {
    
    
            if (i != booleanArray.length - 1) {
    
    
                System.out.print(booleanArray[i] + "  、");
            } else {
    
    
                System.out.println(booleanArray[i]);  //最后一个不需要顿号且换行
            }
        }

        String[] stringArray = new String[5];
        System.out.println("字符类型数组的默认初始化");
        for (int i = 0; i < stringArray.length; i++) {
    
    
            if (i != stringArray.length - 1) {
    
    
                System.out.print(stringArray[i] + "  、");
            } else {
    
    
                System.out.println(stringArray[i]);  //最后一个不需要顿号且换行
            }
        }

结果:

在这里插入图片描述


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

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

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

静态初始化:手动指定数组的元素,系统会根据元素的个数,计算出数组的长度。

动态初始化:手动指定数组长度,由虚拟机给出默认初始化值


9.1 使用场景

只明确元素个数,但是不明确具体的数据,推荐使用动态初始化。

已经明确了要操作的所有数据,推荐使用静态初始化。


9.2 举例

  • 使用数组来存储键盘录入的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) {
    
    
        //1.定义一个数组
        int[] arr = {
    
    1,2,3,4,5};
        //长度:5
        //最小索引:0
        //最大索引:4(数组的长度 - 1)
        System.out.println(arr[10]);  //越界访问,有异常:ArrayIndexOutOfBoundsException
    }
}

在这里插入图片描述


11. 数组的内存图

11.1 空间分配

JDK7以前,堆和方法区是连在一起的,在真实的物理内存当中也是一块连续的空间,但是这种设计方式不是很好。后续讲解~

在这里插入图片描述


从JDK8开始,取消方法区,新增元空间,把原来方法区中的多种功能进行拆分,有的功能放在堆中,有的功能放在元空间中。

在这里插入图片描述


11.2 名称讲解

名称 含义
方法运行时使用的内存,比如main方法运行,进入方法栈中执行
存储对象或者数组,new来创建的,都存储在堆内存
方法区 存储可以运行的class文件
本地方法栈 JVM在使用操作系统功能的时候使用,和我们开发无关
寄存器 给CPU使用,和我们开发无关

11.3 变量的内存讲解

在这里插入图片描述

11.4 数组的内存讲解

在这里插入图片描述


两个数组指向同一个内存空间的内存分配:

在这里插入图片描述


11.5 总结

  1. 只要是new出来的一定是在堆里面开辟了一个小空间
  2. 如果new了多次,那么在堆里面有多个小空间,每个小空间中都有各自的数据。
  3. 空间中的值发生了改变,那么其他数组再次访问的时候都是修改之后的结果了。

12. 二维数组

12.1 什么是二维数组

数组中存放的还是数组。

12.2 二维数组的应用场景

当我们需要把数据分组管理的时候,就需要用到二维数组。

在这里插入图片描述

12.3 二维数组的静态初始化

在这里插入图片描述

package com.thk.twoarraydemo;

public class ArrayDemo1 {
    
    
    public static void main(String[] args) {
    
    
        //1.二维数组静态初始化格式
        //数据类型[][] 数组名 = new 数据类型[][]{
    
    {元素1,元素2},{元素1,元素2}};
        int[][] arr1 = new int[][]{
    
    {
    
    1,2,3},{
    
    4,5,6,7,8}};
        //简化格式
        int[][] arr2 = {
    
    {
    
    1,2,3},{
    
    4,5,6,7,8}};
        //常用格式,把每一个一维数组,单独写成一行
        //注意:每一个一维数组其实是二维数组中的元素,所以每一个一维数组之间需要用逗号隔开。
        // 最后一个一维数组后面不需要加逗号.
        int[][] arr3 = {
    
    
                {
    
    1,2,3},
                {
    
    4,5,6,7,8}
        };

        //2.获取元素
        //arr[i][j]arr:二维数组
        //i:二维数组的索引,获取出来的是里面的一维数组
        //j:表示一维数组中的索引,获取出来的就是真正的元素

        System.out.println(arr3[0]);  //[I@1b6d3586,表示获取二维数组中的第一个一维数组
        //arr3[0]:二维数组中的第一个一维数组
        //arr3[0][0]:获取第一个一维数组中0索引的元素
        System.out.println(arr3[0][0]);  //1
        System.out.println(arr3[1][4]);  //8

//越界访问,Exception in thread "main"java.lang.ArrayIndexOutOfBoundsException: 2
//        System.out.println(arr3[2][0]);

        //3.二维数组遍历:
        //先得到一维数组,再遍历一维数组获取元素
        //外循环:遍历二维数组,得到里面的每一个一维数组
        for (int i = 0; i < arr3.length; i++) {
    
    
            // i:表示二维数组中的每一个索引
            //arr3[i]:表示二维数组中的每一个元素(一维数组)
            //内循环:遍历一维数组,得到里面的每一个元素
            for (int j = 0; j < arr3[i].length; j++) {
    
    
            //j:表示一维数组中的每一个元素
                System.out.print(arr3[i][j]+" ");
            }
            System.out.println();//输出一个一维数组就换行显示
            
/*          1 2 3
            4 5 6 7 8*/
        }
    }
}


12.4 二维数组的动态初始化

在这里插入图片描述

package com.thk.twoarraydemo;

public class ArrayDemo2 {
    
    
    public static void main(String[] args) {
    
    
//        1.利用动态初始化格式创建二维数组
//        3:表示二维数组长度为3,可以装3个一维数组
//        5:表示每一个一维数组的长度都是5,可以装5个int类型的元素
        int[][] arr = new int[3][5];

//        给二维数组赋值一个元素
        arr[0][0] = 10;

//        遍历二维数组
//        外循环:遍历二维数组获取里面的每一个一维数组
//        内循环:遍历一维数组获取每一个元素
        for (int i = 0; i < arr.length; i++) {
    
    
            for (int j = 0; j < arr[i].length; j++) {
    
    
                System.out.print(arr[i][j]+" ");
            }
            System.out.println();
        }
        
/*      10 0 0 0 0
        0 0 0 0 0
        0 0 0 0 0*/

    }
}


12.5 二维数组的内存原理

在这里插入图片描述


12.5.1 特殊情况1

只定义高维数组的长度。

在这里插入图片描述

12.5.2 特殊情况2

首先创建一个二维数组:

在这里插入图片描述

在后面继续创建两个一维数组,并赋值给二维数组中的一维数组,这将会覆盖掉原来的一维数组:

在这里插入图片描述

则原来创建的一维数组就成为了垃圾,进而从内存中消失。

在这里插入图片描述


13. 数组的练习

练习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:求最值

需求:求数组中的最大值

代码示例:

    public static void main(String[] args) {
    
    
        //定义数组求最大值:33,5,22,44,55

        //扩展问题:
        //1.根据求最大值的思路,自己改写一下求最小值
        
        //2.为什么max、min要记录为arr[0],默认值不能为0吗?
        //不能写0,如果说数组里面的数值都是负数。那难道最后的最大值是0吗?数组里面压根没有0!!!!!
        //min、max的初始化值一定要是数组中的值。

        //3.循环中开始条件一定是0吗?
        //循环的开始条件如果为0,那么第一次循环的时候是自己跟自己比了一下,对结果没有任何影响,但是效率偏低
        //为了提高效率,减少一次循环的次数,循环开始条件可以写1.


        //1.定义数组用来存储5个值
        int[] arr = {
    
    33,5,22,44,55};
        //2.定义一个变量max用来存储最大值
        //临时认为0索引的数据是最大的
        int max = arr[0];
        //3.循环获取数组中的每一个元素
        //拿着每一个元素跟max进行比较,从1开始,就不和自己比较了,浪费时间!!!!!
        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

        //临时认为0索引的数据是最小的
        int min = arr[0];
        for (int i = 1; i < arr.length; i++) {
    
    
            if(arr[i] < min){
    
    
                min = arr[i];
            }
        }
        System.out.println("最小值是:"+min);//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:交换数据!!!

交换两个变量值

public static void main(String[] args) {
    
    
        /*
        引入第三者变量
         */
        int v1=1;
        int v2=2;
        System.out.println("v1="+v1+","+"v2="+v2);
        int temp;//定义临时变量
        temp=v1;//实现交换
        v1=v2;
        v2=temp;
        System.out.println("v1="+v1+","+"v2="+v2);

        /*
        运算符,数学思维
        好处:不用再定义临时变量。
        弊端:加法操作可能会导致超出存储范围,并且只能用于数值型变量的交换,有一定的局限性。
         */
        int n1=1;
        int n2=2;
        System.out.println("n1="+n1+","+"n2="+n2);
        n1=n1+n2;   // 得到和  3
        n2=n1-n2;   // 减去一个加数,得到另一个加数,实现交换  1
        n1=n1-n2;   //  在减去另一个数,实现交换  2
        System.out.println("n1="+n1+","+"n2="+n2);

        /*
        异或
         */
        int x1=1;
        int x2=2;
        System.out.println("x1="+x1+","+"x2="+x2);
        x1=x1^x2;
        x2=x1^x2;
        x1=x1^x2;
        System.out.println("x1="+x1+","+"x2="+x2);


    }

交换两个数组值

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

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

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

代码示例:

/*将数组中0索引和最大索引出的值进行交换
交换前:1,2,3,4,5
交换后:5,2,3,4,1
*/
        //1.定义一个数组
        int[] arr = {
    
    1,2,3,4,5};
        //2.将数组中0索引和最大索引出的值进行交换
        //也是可以利用第三方变量进行交换
        int temp = arr[0];
        arr[0] = arr[4];
        arr[4] = temp;
       //3.遍历数组
        for (int i = 0; i < arr.length; i++) {
    
    
            System.out.print(arr[i] + " ");
        }

----------------------------------------------------------------------
/*
交换前:1,2,3,4,5
交换后:5,4,3,2,1

*/
//1.定义数组存储数据
int[] arr = {
    
    1,2,3,4,5};
//2.利用循环去交换数据
        //i < j,当i=j的时候,两个索引相等,是同一个值,就结束判断
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] + " ");
}

----------------------------------------------------------------------
           /*
        引入临时数组
         */
        int[] a  = {
    
    10,20,30,40,50};
        int[] temp =new int[5];  //会默认初始化为0

        for (int i = 0,j = a.length-1; i < a.length; i++,j--) {
    
    
             temp[i]  = a[j];  //将a数组逆序赋值给temp数组
        }

        System.out.println("之前的a数组:");
        for (int i = 0; i < a.length; i++) {
    
    
            System.out.print(a[i]+" ");
        }
        System.out.println();
        System.out.println("temp数组:");
        for (int i = 0; i < temp.length; i++) {
    
    
            System.out.print(temp[i]+" ");
        }
        System.out.println();

        //再重新赋值a数组
        for (int i = 0; i < a.length; i++) {
    
    
            a[i] = temp[i];
        }

        System.out.println("交换之后的a数组:");
        for (int i = 0; i < a.length; i++) {
    
    
            System.out.print(a[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++) {
    
    
    //生成一个随机索引[0,arr.length-1]
    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] + " ");
}

存在的问题:

  上面这份代码并不是将所有的顺序都打乱了。因为你交换之后存在着继续交换回来的情况,亦或者产生相同的索引值。就像洗牌一样。总不可能把54张牌的顺序全部都打乱了吧?只要数据打乱了就行,题目也没要求完全打乱。

练习8:二维数组的练习

某商城每个季度的营业额如下:单位(万元)

第一季度!22,66,44

第二季度:77,33,88

第三季度:25,45,65

第四季度:11,66, 99

要求计算出每个季度的总营业额和全年的总营业额

代码示例:

package com.thk.twoarraydemo;

public class ArrayDemo3 {
/*某商城每个季度的营业额如下:单位(万元)第一季度!22,66,44
第二季度:77,33,88第三季度:25,45,65第四季度:11,66, 99
要求计算出每个季度的总营业额和全年的总营业额*/

    public static void main(String[] args) {
//        1.创建二维数组存储数据
        int[][] yearArr = {
                {22,66,44},
                {77,33,88},
                {25,45,65},
                {11,66,99}
        };

        //定义全年营业额
        int yearSum = 0;
        for (int i = 0; i < yearArr.length; i++) {
            //将一维数组传递进去,得到每一个季度的和
            int sum = getSum(yearArr[i]);
            System.out.println("第"+(i+1)+"一个季度的营业额是:"+sum);
            yearSum += sum;
        }
        System.out.println("全年营业额是:"+yearSum);
    }

    //计算每一个季度的营业额
    public static int getSum(int[] arr) {
        int sum = 0;
        for (int i = 0; i < arr.length; i++) {
            sum = sum + arr[i];
        }
        return sum;
    }
}

猜你喜欢

转载自blog.csdn.net/qq_53139964/article/details/128077575