热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

关于Arrays.sort()的使用方式

如果你想要看Comparable和Comparator的用法,可以点这里:Com

如果你想要看Comparable和Comparator的用法,可以点这里:Comparable和Comparator的比较与使用
今天在写LeetCode题目时,本来想使用Arrays.sort()方法,可以对于其中传入比较器的使用带有疑惑,所以来整理一篇Arrays.sort()的用法。对于需要我们自己去实现排序的题的话,就不要投机取巧使用Arrays.sort()了,如果是一道题的某一步,还是建议使用的。点开IDEA,可以查看到它的用法有很多,但其实可以大致分为几类。

在这里插入图片描述

基本类型的数组排序

不管是哪种基本类型,都是一样的使用方式,所以就用Arrays.sort(int[] a)来举例说明,其内部是按照从小到大排序的。

import java.util.Arrays;
public class ArraysSort1 {
public static void main(String[] args) {
int[] arr = new int[]{1,5,2,3,8,6,9,7,4};
Arrays.sort(arr);
for(int i : arr){
System.out.print(i+" ");
}
}
}

运行结果:

在这里插入图片描述

基本类型数组的指定区域排序

注:该区域为[fromIndex,toIndex),是左闭右开的。内部也是默认从小到大的。

import java.util.Arrays;
public class ArraysSort2 {
public static void main(String[] args) {
int[] arr = new int[]{1,5,3,2,7,8,6,9,4};
for(int i : arr){
System.out.print(i + " ");
}
System.out.println();
Arrays.sort(arr,0,4);
for(int i : arr){
System.out.print(i + " ");
}
}
}
其它类型排序(重点)

1.Arrays.sort(Object[] a)

要是用它则传进来的对象必须是具有比较能力的,所以该对象一定实现了Comparable,并重写了compareTo()方法。java中的很多类都实现了Comparable接口,例如包装类、String类等等。

import java.util.Arrays;
class Person implements Comparable<Person>{
private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
@Override
public int compareTo(Person o) {
return this.age - o.age;
}
}
public class ArraysSort3 {
public static void main(String[] args) {
Person[] peoples = new Person[]{
new Person("张三",17),
new Person("李四",32),
new Person("王五",12),
new Person("赵六",10),
new Person("哈哈",23)
};
System.out.println("排序前:");
for(Person p : peoples){
System.out.println(p);
}
System.out.println("排序后:");
Arrays.sort(peoples);
for(Person p : peoples){
System.out.println(p);
}
}
}

运行结果:

在这里插入图片描述

2.Arrays.sort(T[] a, Comparator c)

显然这是需要传入一个比较器,那么对于比较器就可以直接匿名传入。并且因为它是一个函数式接口,所以可以用直接使用lambda表达式。下面我们直接拿一道LeetCode原题来看吧。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-cPUocaiu-1609830881770)(C:\Users\高飞\AppData\Roaming\Typora\typora-user-images\image-20210105145910762.png)]

import java.util.Arrays;
import java.util.Comparator;
public class Offer45 {
public String minNumber(int[] nums){
//1.整形数组转换为字符串数组
String[] strs = new String[nums.length];
for(int i = 0 ; i < nums.length; i++){
strs[i] = String.valueOf(nums[i]);
}
//2.按照需求进行排序
Arrays.sort(strs, new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
//这里我们需要按照自己的需求来重写compare方法
//String底层本身就实现了Comparable,所以我们调用它的compareTo方法即可。
return (o1+o2).compareTo(o2+o1);
}
});

//也可以直接写成lambda表达式形式。
/*Arrays.sort(strs,(s1,s2)->(s1+s2).compareTo((s2+s1)));*/

//3.拼接字符串
StringBuilder sb = new StringBuilder();
for(String s : strs){
sb.append(s);
}
return sb.toString();
}
}

注:剩下的两个其实本质上刚才都讲过了,大家可以自己尝试。


推荐阅读
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • Java 类成员初始化顺序与数组创建
    本文探讨了Java中类成员的初始化顺序、静态引入、可变参数以及finalize方法的应用。通过具体的代码示例,详细解释了这些概念及其在实际编程中的使用。 ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • Java 中 Writer flush()方法,示例 ... [详细]
  • 本文介绍了如何使用 Spring Boot DevTools 实现应用程序在开发过程中自动重启。这一特性显著提高了开发效率,特别是在集成开发环境(IDE)中工作时,能够提供快速的反馈循环。默认情况下,DevTools 会监控类路径上的文件变化,并根据需要触发应用重启。 ... [详细]
  • Java 中的 BigDecimal pow()方法,示例 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 主要用了2个类来实现的,话不多说,直接看运行结果,然后在奉上源代码1.Index.javaimportjava.awt.Color;im ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 将Web服务部署到Tomcat
    本文介绍了如何在JDeveloper 12c中创建一个Java项目,并将其打包为Web服务,然后部署到Tomcat服务器。内容涵盖从项目创建、编写Web服务代码、配置相关XML文件到最终的本地部署和验证。 ... [详细]
author-avatar
手机用户2502912633
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有