文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java实现字符串排序的几种方式

2023-09-14 08:33

关注

创建实体类(此处引入了lombok)

@Data@AllArgsConstructor@NoArgsConstructorpublic class Test{    private int Id;    private String TestNo;}

一、使用List集合中自带的sort方法(字符串的位数保持一致,不一致的情况可以在左边补0,也可以使用String.format()方法补全)

在对象排序中使用

public static void main(String[] args) {        List testList= new ArrayList<>();        testList.add(1,"22");        testList.add(2,"11");        testList.add(3,"44");        testList.add(4,"33");        list.sort((a,b)->a.getTestNo().compareTo(b.getTestNo()));}

在字符串排序中使用

public static void main(String[] args) {        List testList= new ArrayList<>();        testList.add("22");        testList.add("11");        testList.add("44");        testList.add("33");        list.sort(String::compareTo);}

二、使用Stream流(字符串的位数保持一致,不一致的情况可以在左边补0,也可以使用String.format()方法补全)

在对象排序中使用

public static void main(String[] args) {        List testList= new ArrayList<>();        testList.add(1,"22");        testList.add(2,"11");        testList.add(3,"44");        testList.add(4,"33");        List sortList = testList.stream().sorted(Comparator.comparing(Test::getTestNo).collect(Collectors.toList());}

在字符串排序中使用

public static void main(String[] args) {        List testList= new ArrayList<>();        testList.add("22");        testList.add("11");        testList.add("44");        testList.add("33");        List collect = testList.stream().sorted(Comparator.comparing(Objects::toString)).collect(Collectors.toList());}

三、使用基数排序(此处仅展示对字符串进行排序,不需要补全位数)

class Quick3string{//三向字符串快速排序private static int charAt(String s, int d) {if(d < s.length()) {return s.charAt(d);}return -1;}    public static void sort(String[] a) {sort(a, 0, a.length - 1, 0);}    private static void sort(String[] a, int lo, int hi, int d) {if(hi <= lo) {return;}int lt = lo, gt = hi, i = lo + 1;int v = charAt(a[lo], d);while(i <= gt) {int t = charAt(a[i], d);if(t < v) {exch(a, lt++, i++);}else if(t > v) {exch(a, i, gt--);}else {i++;}}//a[lo..lt-1] < v = a[lt..gt] < a[gt+1..hi]sort(a, lo, lt - 1, d);if(v >= 0) {sort(a, lt, gt, d + 1);}sort(a, gt + 1, hi, d);}    private static void exch(String[] a, int i, int j) {String t = new String(a[i]);a[i] = a[j];a[j] = t;}public static void main(String[] args) {String[] a = {"48328458C70490693231303331361020", "48326E48E1136A9E3139313131301020", "48326E48E1176F8A3139313131311020", "48326E48E12474713139313131311020"};Quick3string.sort(a);System.out.println(Arrays.toString(a));}}

来源地址:https://blog.csdn.net/AppTop_Jo/article/details/130576226

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯