猿创征文 | Java知识【数组下篇】

举报
爱吃豆的土豆 发表于 2022/09/25 04:33:26 2022/09/25
【摘要】 目录 1,索引 索引的特点: 2,数组的遍历 3,数组的动态初始化 格式: 举例: 数组的默认初始化值: 4,数组两种初始化方式的区别 使用场景: 举例: 5,数组常见问题 6,数组的练习 练习1:求和 练习2:统计个数 练习3:变化数据 练习4:求最值 练习5:统计个数 练习6:交换数据 练习7:...

目录

1,索引

索引的特点:

2,数组的遍历

3,数组的动态初始化

格式:

举例:

数组的默认初始化值:

4,数组两种初始化方式的区别

使用场景:

举例:

5,数组常见问题

6,数组的练习

练习1:求和

练习2:统计个数

练习3:变化数据

练习4:求最值

练习5:统计个数

练习6:交换数据

练习7:打乱数据


1,索引

索引的特点:

  • 索引一定是从0开始的。

  • 连续不间断。

  • 逐个+1增长。

2,数组的遍历

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

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

通用代码:


  
  1. for(int i = 0; i < arr.length; i++){
  2. //在循环的过程中,i依次表示数组中的每一个索引
  3. sout(arr[i]);//就可以把数组里面的每一个元素都获取出来,并打印在控制台上了。
  4. }

3,数组的动态初始化

格式:

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

举例:


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

数组的默认初始化值:

整数类型:0

小数类型:0.0

布尔类型:false

字符类型:'\u0000'

引用类型:null

4,数组两种初始化方式的区别

静态初始化: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};

5,数组常见问题

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

避免:

针对于任意一个数组,索引的范围: 最小索引:0 最大索引:数组的长度 - 1 数组名.length - 1


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

6,数组的练习

练习1:求和

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

遍历数组得到每一个元素,求数组里面所有的数据和

代码示例:


  
  1. /*定义一个数组,存储1,2,3,4,5
  2. 遍历数组得到每一个元素,求数组里面所有的数据和*/
  3. //分析:
  4. //1.定义一个数组,并添加数据1,2,3,4,5
  5. int[] arr = {1,2,3,4,5};
  6. //求和变量
  7. int sum = 0;
  8. //2.遍历数组得到每一个数据,累加求和
  9. for (int i = 0; i < arr.length; i++) {
  10. //i 依次表示数组里面的每一个索引
  11. //arr[i] 依次表示数组里面的每一个元素
  12. sum = sum + arr[i];
  13. }
  14. //当循环结束之后,sum的值就是累加之后的结果
  15. System.out.println(sum);

练习2:统计个数

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

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

代码示例:


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

练习3:变化数据

需求:

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

遍历数组得到每一个元素。

要求:

1,如果是奇数,则将当前数字扩大两倍

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

代码示例:


  
  1. //分析:
  2. //1.定义一个数组,存1,2,3,4,5,6,7,8,9,10
  3. int[] arr = {1,2,3,4,5,6,7,8,9,10};
  4. //2.遍历数组得到每一个元素
  5. for (int i = 0; i < arr.length; i++) {
  6. //i 依次表示数组里面的每一个索引
  7. //arr[i] 依次表示数组里面的每一个元素
  8. //3.对每一个元素进行判断
  9. if(arr[i] % 2 == 0){
  10. //偶数 变成二分之一
  11. arr[i] = arr[i] / 2;
  12. }else{
  13. //奇数 扩大两倍
  14. arr[i] = arr[i] * 2;
  15. }
  16. }
  17. //遍历数组
  18. //一个循环尽量只做一件事情。
  19. for (int i = 0; i < arr.length; i++) {
  20. System.out.println(arr[i]);
  21. }

练习4:求最值

需求:求数组中的最大值

代码示例:


  
  1. //定义数组求最大值:33,5,22,44,55
  2. //扩展问题:
  3. //1.根据求最大值的思路,自己改写一下求最小智
  4. //2.为什么max要记录为arr[0],默认值不能为0吗?
  5. //不能写0
  6. //max的初始化值一定要是数组中的值。
  7. //3.循环中开始条件一定是0吗?
  8. //循环的开始条件如果为0,那么第一次循环的时候是自己跟自己比了一下,对结果没有任何影响,但是效率偏低
  9. //为了提高效率,减少一次循环的次数,循环开始条件可以写1.
  10. //1.定义数组用来存储5个值
  11. int[] arr = {33,5,22,44,55};
  12. //2.定义一个变量max用来存储最大值
  13. //临时认为0索引的数据是最大的
  14. int max = arr[0];
  15. //3.循环获取数组中的每一个元素
  16. //拿着每一个元素跟max进行比较
  17. for (int i = 1; i < arr.length; i++) {
  18. //i 索引 arr[i] 元素
  19. if(arr[i] > max){
  20. max = arr[i];
  21. }
  22. }
  23. //4.当循环结束之后,max记录的就是数组中的最大值
  24. System.out.println(max);//55

练习5:统计个数

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

1)求出所有数据的和

2)求所有数据的平均数

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

代码示例:


  
  1. //分析:
  2. //1.定义数组
  3. int[] arr = new int[10];
  4. //2.把随机数存入到数组当中
  5. Random r = new Random();
  6. for (int i = 0; i < arr.length; i++) {
  7. //每循环一次,就会生成一个新的随机数
  8. int number = r.nextInt(100) + 1;
  9. //把生成的随机数添加的数组当中
  10. //数组名[索引] = 数据;
  11. arr[i] = number;
  12. }
  13. // 1)求出所有数据的和
  14. //定义求和变量
  15. int sum = 0;
  16. for (int i = 0; i < arr.length; i++) {
  17. //循环得到每一个元素
  18. //并把元素累加到sum当中
  19. sum = sum + arr[i];
  20. }
  21. System.out.println("数组中所有数据的和为:" + sum);
  22. //2)求所有数据的平均数
  23. int avg = sum / arr.length;
  24. System.out.println("数组中平均数为:" + avg);
  25. //3)统计有多少个数据比平均值小
  26. int count = 0;
  27. for (int i = 0; i < arr.length; i++) {
  28. if(arr[i] < avg){
  29. count++;
  30. }
  31. }
  32. //当循环结束之后,就表示我已经找到了所有的比平均数小的数据
  33. System.out.println("在数组中,一共有" + count + "个数据,比平均数小");
  34. //遍历数组,验证答案
  35. for (int i = 0; i < arr.length; i++) {
  36. System.out.print(arr[i] + " ");
  37. }

练习6:交换数据

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

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

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

代码示例:


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

练习7:打乱数据

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

代码示例:


  
  1. //1.定义数组存储1~5
  2. int[] arr = {1, 2, 3, 4, 5};
  3. //2.循环遍历数组,从0索引开始打乱数据的顺序
  4. Random r = new Random();
  5. for (int i = 0; i < arr.length; i++) {
  6. //生成一个随机索引
  7. int randomIndex = r.nextInt(arr.length);
  8. //拿着随机索引指向的元素 跟 i 指向的元素进行交换
  9. int temp = arr[i];
  10. arr[i] = arr[randomIndex];
  11. arr[randomIndex] = temp;
  12. }
  13. //当循环结束之后,那么数组中所有的数据已经打乱顺序了
  14. for (int i = 0; i < arr.length; i++) {
  15. System.out.print(arr[i] + " ");
  16. }

文章来源: qianxu.blog.csdn.net,作者:爱吃豆的土豆,版权归原作者所有,如需转载,请联系作者。

原文链接:qianxu.blog.csdn.net/article/details/126804935

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。