Java数组

目录

一、定义

二、使用

2.1遍历数组

2.2获取数组长度

三、Arrays类

3.1数组填充

3.2数组排序

3.3数组转为字符串

3.4数组比较

3.5二分搜索

3.6数组复制

二维数组


一、定义

数组表示一个相同类型元素的集合

对于一个数组,可以有以下几种定义方法

java 复制代码
int[] array1 = {1,2,3,4,5};
int[] array2 = new int[]{1,2,3,4,5};
int[] array3 = new int[10];   //并没有进行初始化

tips:

  • 对数组进行整体初始化,只能在定义数组的时候进行
  • 存储类型为引用类型时,默认值为NULL
  • 存储类型为布尔类型时,默认值为false
  • 存储类型为整型时,默认值为0

二、使用

2.1遍历数组

for循环语句与C相同,具体可以参考这篇文章Java运算符&逻辑控制&输入输出_java1.8 加减乘除-CSDN博客https://blog.csdn.net/stillaliveQEJ/article/details/142864406?spm=1001.2014.3001.5501

另外,Java提供了另外一种遍历方法,for each循环

java 复制代码
for(int i : array){
    //......代码主体
}
//array为一个int类型的数组

与普通的for循环不同,for each循环无法获取到对应的下标,因此在一些不需要数组下标的情境下比较适用

2.2获取数组长度

在确定数组长度时,可以使用array.length获得(array是数组名字),这是因为array中包含length等属性

三、Arrays类

Arrays类是一个非常有用的工具类,它提供了一系列静态方法来操作数组,如排序、搜索、比较和填充等。这个类位于java.util包中,因此在使用前需要导入这个包

以下是Arrays类中的一些常用方法

3.1数组填充

java 复制代码
//创建一个大小为5的数组并填充4
int[] arr = new int[5];
Arrays.fill(arr, 4);
//从索引2到4(不包含4)的位置填充为6
Arrays.fill(arr, 2, 4, 6);

3.2数组排序

java 复制代码
//默认是按字典顺序进行的
Arrays.sort(arr);

3.3数组转为字符串

java 复制代码
int[] arr = {3,2,1,5,4};
System.out.println(Arrays.toString(arr));
//输出结果为[3, 2, 1, 5, 4]

3.4数组比较

java 复制代码
int[] arr1 = {1,2,3};
int[] arr2 = {1,2,3};
System.out.println(Arrays.equals(arr1, arr2));
//输出结果为true

3.5二分搜索

java 复制代码
//该方法可以用来快速查找数组中的对应元素并返回其索引值
int[] arr = {10,20,30,40,50};
System.out.println(Arrays.binarySearch(arr, 30));
//输出结果为2

3.6数组复制

java 复制代码
int[] arr = {10,20,30,40,50};
//复制整个数组
int[] brr = Arrays.copyOf(arr, arr.length);
//brr的元素为{10,20,30,40,50}
//复制数组的前三个元素
int[] crr = Arrays.copyOf(arr, 3);
//crr的元素为{10,20,30}
//复制数组的指定范围(索引1-3)
int[] part = Arrays.copyOfRange(arr, 1, 3);
//crr的元素为{10,20,30}

二维数组

Java中的二位数组与C语言中的没有太多出入,需要注意的是,Java中对二维数组初始化时需要手动指定行和列,可以不写列,但是一定要写行;C语言则是行可以省略,列必须保留。

这里介绍一个方法,用于二维数组的打印

java 复制代码
int[][] array = {{1,2},{3,4}};
System.out.println(Arrays.deepToString(array).toString());
//输出结果为[[1, 2], [3, 4]]
相关推荐
.小小陈.37 分钟前
数据结构6:排序
数据结构
海琴烟Sunshine3 小时前
leetcode 383. 赎金信 python
python·算法·leetcode
cynicme9 小时前
力扣3228——将 1 移动到末尾的最大操作次数
算法·leetcode
熬了夜的程序员9 小时前
【LeetCode】109. 有序链表转换二叉搜索树
数据结构·算法·leetcode·链表·职场和发展·深度优先
随意起个昵称9 小时前
【递归】二进制字符串中的第K位
c++·算法
mjhcsp10 小时前
C++ 循环结构:控制程序重复执行的核心机制
开发语言·c++·算法
立志成为大牛的小牛10 小时前
数据结构——四十一、分块查找(索引顺序查找)(王道408)
数据结构·学习·程序人生·考研·算法
xier_ran10 小时前
深度学习:RMSprop 优化算法详解
人工智能·深度学习·算法
地平线开发者10 小时前
不同传感器前中后融合方案简介
算法·自动驾驶
地平线开发者10 小时前
征程 6X 常见 kernel panic 问题
算法·自动驾驶