数组(定义,静态初始化,地址值,元素访问,索引,遍历,动态初始化,两种初始化的区别,练习)

文章目录

  • 1.数组
      • 概念:
  • 2.数组的定义
      • 格式一:
      • 格式二:
      • 详解:
      • 注意点:
  • 3.数组的静态初始化
      • 完整格式:
      • 格式详解:
      • 注意点:
      • 简化格式:
      • 练习1:
      • 练习2:
      • 练习3:
  • 4.地址值
  • 5.数组元素访问
      • 格式:
      • 作用:
      • 代码示例:
  • 6.索引
      • 索引的特点:
  • 7.数组的遍历
  • 8.数组的动态初始化
      • 格式:
      • 举例:
      • 数组的默认初始化值:
  • 9.数组两种初始化方式的区别
      • 使用场景:
      • 举例:
  • 10.数组常见问题
  • 11.数组的练习
    • 练习1:求和
    • 练习2:统计个数
    • 练习3:变化数据
    • 练习4:求最值
    • 练习5:统计个数
    • 练习6:交换数据
    • 练习7:打乱数据

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@6d03e736double[] 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索引上的值修改为10arr[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] + " ");
}

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/311306.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

uniapp二维码有效期倒计时三分钟的效果是实现

需求&#xff1a; 会员码时效只有3分钟有效期&#xff0c;需要在页面倒计时3分钟&#xff0c;没有长按保存的效果实现 效果&#xff1a; 代码&#xff1a; <templete> <view> <uni-list> <view class"custom-list-item" click"onCode(c…

音视频基本概念

多线程好处 充分利用cpu资源的工具 多线程带来的问题 多线程管理问题 线程的互斥与同步 互斥 资源 有限多个人去抢 同步 有序进行 锁的种类 读写锁 读写分离 自旋锁 等待资源释放&#xff08;例如&#xff09; 可重入锁 SDL锁 互斥锁 SDL_CreateMutex/SDL_Destro…

请将简单的代码推给AI

如火如荼的人工智能火遍人类&#xff0c;如果您已非稚请将简单的事儿推给AI。 (笔记模板由python脚本于2023年12月31日 18:11:16创建&#xff0c;本篇笔记适合能写出一行代码的所有人的coder翻阅) 【学习的细节是欢悦的历程】 Python 官网&#xff1a;https://www.python.org/ …

以太坊代币标准解读及相关Dapp的搭建

文章目录 什么是以太坊代币标准1、什么是以太坊2、以太坊代币标准 同质化代币 Dapp 搭建1、MetaMask 的安装2、Ganache 的安装3、实现 ERC-20 代币协议4、前端页面的编写5、部署流程及操作演示 什么是以太坊代币标准 1、什么是以太坊 以太坊&#xff08;Ethereum&#xff09;是…

vue3中pinia的使用及持久化(详细解释)

解释一下pinia&#xff1a; Pinia是一个基于Vue3的状态管理库&#xff0c;它提供了类似Vuex的功能&#xff0c;但是更加轻量化和简单易用。Pinia的核心思想是将所有状态存储在单个store中&#xff0c;并且将store的行为和数据暴露为可响应的API&#xff0c;从而实现数据&#…

OpenCV-11颜色通道的分离与合并

本次我们使用两个比较重要的API split&#xff08;mat&#xff09;将图像的通道进行分割。 merge&#xff08;(ch1&#xff0c;ch2&#xff0c;ch3)&#xff09;将多个通道进行融合。 示例代码如下&#xff1a; import cv2 import numpy as npimg np.zeros((480, 640, 3),…

独立站的营销策略:吸引顾客的秘密武器

一、独立站的重要性 独立站是指企业自主建立的电子商务网站&#xff0c;具有独立的域名和运营管理权。通过独立站&#xff0c;企业可以展示产品信息、提供在线服务、进行促销活动等&#xff0c;与顾客建立互动和信任关系。独立站的重要性在于它可以帮助企业建立品牌认知度、提…

springboot 双数据源配置

1:pom <!--SpringBoot启动依赖--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</group…

计算机组成原理复习7

内存管理 文章目录 内存管理存储器概述存储器的分类按在计算机中的作用&#xff08;层次&#xff09;分类按存储介质分类按存取方式分类按信息的可保存性分类 存储器的性能指标存储容量单位成本存储速度&#xff1a;数据传输率数据的宽度/存储周期 存储器的层次化结构多级存储系…

我与旧事归于尽,来年依旧迎花开。

弹指间&#xff0c;这一年辗转已过&#xff0c;今天已是2023年的最后一天。 这一年里&#xff0c;烦累有时&#xff0c;苦痛亦有时&#xff0c;每个人都过得艰辛&#xff0c;活得不易。 这一年里&#xff0c;自己对于生活、工作的规划安排相较于2022年稍微规整了些。 在生活…

STM32H743 各个外设功能整理

在整理工程时看到芯片很多的外设自己都没有使用到&#xff0c;用到的只有三分之一左右&#xff0c;遂参考芯片手册和网上的资料对芯片的外设功能进行了一些整理&#xff0c;之后需要用到这些功能时可以及时的查到。 注意&#xff1a;该表格是以hal库名称为基础整理的&#xff0…

迭代归并:归并排序非递归实现解析

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《数据结构&算法》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! &#x1f4cb; 前言 归并排序的思想上我们已经全部介绍完了&#xff0c;但是同时也面临和快速排序一样的问题那就是递…