Arrays 类操作 Java 中的数组

使用 Arrays 类操作 Java 中的数组
Arrays 类是 Java 中提供的一个工具类,在 java.util 包中。该类中包含了一些方法用来直接操作数组,比如可直接实现数组的排序、搜索等(关于类和方法的相关内容在后面的章节中会详细讲解滴~~)。

Arrays 中常用的方法:

1、 排序

语法: Arrays.sort(数组名);

可以使用 sort( ) 方法实现对数组的排序,只要将数组名放在 sort( ) 方法的括号中,就可以完成对该数组的排序(按升序排列),如:

运行结果:

2、 将数组转换为字符串

语法: Arrays.toString(数组名);

可以使用 toString( ) 方法将一个数组转换成字符串,该方法按顺序把多个数组元素连接在一起,多个元素之间使用逗号和空格隔开,如:

运行结果为:

输出数组nums中的元素:[25,7,126,53,14,86]

Arrays 类还提供了许多其他方法来操作数组此处就不一一列举啦,各位小伙伴们可以在 wiki 查阅更多信息

任务
亲, Arrays 类的使用您掌握了嘛,让我们来检验一下吧。

在编辑器中定义了一个数组 hobbys ,请在第 2、11、14 行中将代码填写完整,实现使用 Arrays 类对数组进行排序并转换输出。

运行结果为: [ game , movie , sports ]

//导入Arrays类
import java.util.Arrays;

public class HelloWorld {
public static void main(String[] args) {

	// 定义一个字符串数组
	String[] hobbys = { "sports", "game", "movie" };
    
	// 使用Arrays类的sort()方法对数组进行排序
	Arrays.sort(hobbys);
    
	// 使用Arrays类的toString()方法将数组转换为字符串并输出
	System.out.println( Arrays.toString(hobbys)           );
}

}

Arrays类应用
Arrays 类是 Java API 中提供的类,在 java.util 包中, Arrays类中提供的方法可直接实现数组的排序、搜索等。常用方法如下:

1、toString

转换数组:将指定数组内容转换为字符串形式

2、fill

给数组赋值:通过fill方法。

3、sort

对数组排序:通过sort方法,默认按升序。

4、equals

比较数组:通过equals方法比较数组中元素值是否相等。

5、binarySearch

二分查找:使用二分搜索法来搜索指定数组的范围

示例代码:

import java.util.Arrays;

public class HelloWorld {

public static void main(String[] args) {

   int[] array = new int[5];

   // 填充数组

   /* Arrays.fill( a1, value );

     作用:填充 a1 数组中的每个元素都是value

   */

   Arrays.fill(array, 5);

   System.out.println("填充数组:Arrays.fill(array, 5):");

   System.out.println(Arrays.toString(array));



   // 将数组的第3和第4个元素赋值为8

   /* Arrays.fill( a1, fromIndex, toIndex,value);

     作用:填充 a1 数组中的从索引为 fromIndex 开始到索引为 toIndex-1 为止每个元素都是 value

   */

   Arrays.fill(array, 2, 4, 8);

   System.out.println("将数组的第2和第3个元素赋值为8:Arrays.fill(array, 2, 4, 8):");

   System.out.println(Arrays.toString(array));

  

   int[] array1 = { 7, 8, 3, 2, 12, 6, 3, 5, 4 };

   // 对数组的第3个到第7个进行排序

   /* Arrays.sort( a1, fromIndex, toIndex);

     作用:对 a1 数组中的从索引为 fromIndex 开始到索引为 toIndex-1 为止每个元素排序

   */

   Arrays.sort(array1, 2, 7);

   System.out.println("对数组的第2个到第6个元素进行排序:Arrays.sort(array,2,7):");

   System.out.println(Arrays.toString(array1));



   // 对整个数组进行排序

   Arrays.sort(array1);

   System.out.println("对整个数组进行排序:Arrays.sort(array1):");

   System.out.println(Arrays.toString(array1));



   // 比较数组元素是否相等

   System.out.println("比较数组元素是否相等:Arrays.equals(array, array1):" + "\n"

          + Arrays.equals(array, array1));

   int[] array2 = array1.clone();

   System.out.println("克隆后数组元素是否相等:Arrays.equals(array1, array2):" + "\n"

          + Arrays.equals(array1, array2));



   // 使用二分搜索算法查找指定元素所在的下标(必须是排序好的,否则结果不正确)

   Arrays.sort(array1);

   System.out.println("元素3在array1中的位置:Arrays.binarySearch(array1, 3):"

          + "\n" + Arrays.binarySearch(array1, 3));



   // 如果不存在就返回负数

   System.out.println("元素9在array1中的位置:Arrays.binarySearch(array1, 9):"

          + "\n" + Arrays.binarySearch(array1, 9));

}

}

运行结果:

填充数组:Arrays.fill(array, 5):
[5, 5, 5, 5, 5]
将数组的第2和第3个元素赋值为8:Arrays.fill(array, 2, 4, 8):
[5, 5, 8, 8, 5]
对数组的第2个到第6个元素进行排序:Arrays.sort(array,2,7):
[7, 8, 2, 3, 3, 6, 12, 5, 4]
对整个数组进行排序:Arrays.sort(array1):
[2, 3, 3, 4, 5, 6, 7, 8, 12]
比较数组元素是否相等:Arrays.equals(array, array1):
false
克隆后数组元素是否相等:Arrays.equals(array1, array2):
true
元素3在array1中的位置:Arrays.binarySearch(array1, 3):
1
元素9在array1中的位置:Arrays.binarySearch(array1, 9):
-9

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值