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]]
相关推荐
kyle~1 小时前
C++---嵌套类型(Nested Types)封装与泛型的基石
开发语言·c++·算法
sali-tec1 小时前
C# 基于halcon的视觉工作流-章48-短路断路
开发语言·图像处理·人工智能·算法·计算机视觉
墨染点香1 小时前
LeetCode 刷题【128. 最长连续序列】
算法·leetcode·职场和发展
被AI抢饭碗的人1 小时前
算法题(240):最大食物链计数
算法
熬了夜的程序员1 小时前
【LeetCode】82. 删除排序链表中的重复元素 II
数据结构·算法·leetcode·链表·职场和发展·矩阵·深度优先
欧克小奥2 小时前
Floyd判圈算法(Floyd Cycle Detection Algorithm)
算法·floyd
熬了夜的程序员3 小时前
【LeetCode】83. 删除排序链表中的重复元素
算法·leetcode·链表
胖咕噜的稞达鸭3 小时前
AVL树手撕,超详细图文详解
c语言·开发语言·数据结构·c++·算法·visual studio
熊猫钓鱼>_>3 小时前
Rust语言特性深度解析:所有权、生命周期与模式匹配之我见
算法·rust·软件开发·函数·模式匹配·异步编程·质量工具
芒果量化4 小时前
Optuna - 自动调参利器&python实例
开发语言·python·算法·机器学习