自定义排序与Arrays.sort()

本篇题目来源:2022/11/13 Leetcode每日一题:https://leetcode.cn/problems/custom-sort-string

给定两个字符串 order 和 s 。order 的所有单词都是 唯一 的,并且以前按照一些自定义的顺序排序。
对 s 的字符进行置换,使其与排序的 order 相匹配。更具体地说,如果在 order 中的字符 x 出现字符 y 之前,那么在排列后的字符串中, x 也应该出现在 y 之前。
返回 满足这个性质的 s 的任意排列 。 示例1:
输入: order = "cba", s = "abcd"
输出: "cbad"
解释:
“a”、“b”、“c”是按顺序出现的,所以“a”、“b”、“c”的顺序应该是“c”、“b”、“a”。
因为“d”不是按顺序出现的,所以它可以在返回的字符串中的任何位置。“dcba”、“cdba”、“cbda”也是有效的输出。 示例2:
输入: order = "cbafg", s = "abcd"
输出: "cbad"

这是一道字符串自定义排序题,即按照一个约定的顺序,给字符串进行排序。

对于数组,Java提供了一个排序方法:Arrays.sort()。该函数有多个重载,对基本类型和引用类型均有排序。不过对于基本类型来说,只可按照默认顺序进行排序,无法自定义Comparator(原因:基本类型不能作为泛型);而对于引用类型,则可以自定义Comparator以实现自定义排序的效果。

  • 基本类型也可以通过对应的包装类以实现自定义排序的功能

解题

1.对于这道题来说,首先需要将给定的顺序:order数组转为一个可比较顺序的int[]:

//表顺序的数组,这样,调用orders[c] = i即可表示:c排在order中的第i位
int[] orders = new int[26];
for(int i = 0; i < order.length(); ++i) {
orders[order.charAt(i) - 'a'] = i;
}

2.有了顺序后,就可以使用Arrays.sort()进行自定义排序:

//使用char的包装类Character以支持自定义排序
Character[] ans = new Character[s.length()];
for(int i = 0; i < s.length(); ++i) {
ans[i] = s.charAt(i);
}
//使用lambda表达式来简化Comparator的内容
Arrays.sort(ans, (c1, c2) -> orders[c1 - 'a'] - orders[c2 - 'a']);

扩展

实际上,Java不仅对数组类型提供了Arrays.sort()方法,对List类型同样提供了sort()方法,并且功能基本一致

 

同样,也可以对List的内容进行自定义排序,比如,有一个People实体类,结构如下:

public class People {
private String name;
private int age; public People(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 "People{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}

现在,想根据People实体类中的age参数对People List进行排序,就可以通过List中的sort()方法来写自定义的Comparator:

import java.util.ArrayList;
import java.util.Comparator;
import java.util.List; public class PeopleSortDemo {
public static void main(String[] args) {
People p1 = new People("Bob", 25);
People p2 = new People("Lily", 30);
People p3 = new People("Li Ming", 18); List<People> peopleList = new ArrayList<>();
peopleList.add(p1);
peopleList.add(p2);
peopleList.add(p3); peopleList.sort((pa, pb) -> pa.getAge() - pb.getAge()); System.out.println(peopleList);
}
}

结果如下:

最新文章

  1. 泛函编程(3)-认识Scala和泛函编程
  2. Linq 101 工具和源码
  3. Relax NG 在Odoo中的应用
  4. MVC HtmlHelper用法(一)@Html.BeginForm的使用总结
  5. mac下163企业邮箱客户端的配置
  6. Project Euler P105:Special subset sums: testing 特殊的子集和 检验
  7. HTTP权威指南学习心得
  8. flex数据交互方式 转
  9. aop aspect
  10. is not mapped 解决方法
  11. 闭锁——CountDownLatch
  12. Go生成easyjson文件
  13. RNQOJ 21 FBI数
  14. python环境与PyDev IDE配置
  15. Kafka实战-Kafka到Storm
  16. mariadb multi-source replication(mariadb多主复制)
  17. 【BZOJ】1832: [AHOI2008]聚会
  18. echart力导向图
  19. c#代码阅读
  20. 从普通函数到对象方法 ------Windows窗口过程的面向对象封装

热门文章

  1. KingbaseES 的行列转换
  2. 统一建模语言UML---类图
  3. Windows客户端DNS工作原理
  4. PHP获取当前周一、周末时间等(持续更新)
  5. nginx日志参数及含义
  6. PAT (Basic Level) Practice 1014 福尔摩斯的约会 分数 20
  7. String简介
  8. instanceof的使用和向下转型
  9. PHP cURL抓取网上图片
  10. 通过URL保存文件