当前位置: 首页 > article >正文

Java字符串(包含字母和数字)通用排序

说明:本文章是之前查到的一篇安卓版的,具体原文路径忘记了。稍微改了一点,挺符合业务使用的!

一、看代码

/**
     * 包含数字的字符串进行比较(按照从小到大排序)
     */
    private static Integer compareString(String string1, String string2) {
        //拆分两个字符串
        List<String> list1 = splitString(string1);
        List<String> list2 = splitString(string2);
        //依次对比拆分出的每个值
        int index = 0;
        while (true) {
            //相等表示两个字符串完全相等
            if (index >= Math.max(list1.size(), list2.size())) {
                return 0;
            }
            String str1 = null;
            if (index < list1.size()){
                str1 = list1.get(index);
            }else{
                str1 =  "";
            }
            String str2 = null;
            if (index < list2.size()){
                str2 = list2.get(index);
            }else{
                str2 =  "";
            }
            //字符串相等则继续判断下一组数据
            if (str1.equals(str2)) {
                index++;
                continue;
            }
            //是纯数字,比较数字大小
            if (isNum(str1) && isNum(str2)) {
                if(Integer.parseInt(str1) < Integer.parseInt(str2)){
                    return -1;
                }else{
                    return 1;
                }
            }
            // 字符串比较大小
            if(str1.compareTo(str2)>0){
                return -1;
            }else{
                return 1;
            }
        }
    }
/**
     * 是否是纯数字
     */
    private static Boolean isNum(String str){
        return Pattern.compile("\\d+").matcher(str).matches();
    }
/**
     * 拆分字符串
     * 输入:第5章第100节课
     * 返回:[第,5,章第,100,节课]
     */
    private static List<String> splitString(String str){
        Matcher matcher = Pattern.compile("([^0-9]+)|(\\d+)").matcher(str);
        List<String> list = new ArrayList<>();
        while (matcher.find()) {
            list.add(matcher.group());
        }
        return list;
    }

二、看测试

List<String> strList0 = Arrays.asList(new String[]{
	       "4","2","5","1"
	});
	Collections.sort(strList0,(o1, o2) -> compareString(o1, o2));
	System.out.println(Arrays.asList(strList0));
	// 输出:[[1, 2, 4, 5]]
	
	List<String> strList1 = Arrays.asList(new String[]{
	       "GSM 1900","GSM 1800","GSM 850","GSM 900"
	});
	Collections.sort(strList1,(o1, o2) -> compareString(o1, o2));
	System.out.println(Arrays.asList(strList1));
	// 输出:[[GSM 850, GSM 900, GSM 1800, GSM 1900]]
	
	List<String> strList2 = Arrays.asList(new String[]{
	       "6G","2.4G","5G"
	});
	Collections.sort(strList2,(o1, o2) -> compareString(o1, o2));
	System.out.println(Arrays.asList(strList2));
	// 输出:[[2.4G, 5G, 6G]]
	
	List<String> strList3 = Arrays.asList(new String[]{
	       "n78","DC_12A_n2A","n8","DC_66A_n2A","DC_1A_n77A","DC_2A_n41A"
	});
	Collections.sort(strList3,(o1, o2) -> compareString(o1, o2));
	System.out.println(Arrays.asList(strList3));
	// 输出:[n8, n78, DC_1A_n77A, DC_2A_n41A, DC_12A_n2A, DC_66A_n2A]]

三、对象测试

@Data
public class SarKeyValVO {

    private Integer key;

    private String band;
}
List<SarKeyValVO> sarKeyValVOS = new ArrayList<>();
  sarKeyValVOS.add(new SarKeyValVO(0,"GSM 1900"));
  sarKeyValVOS.add(new SarKeyValVO(1,"GSM 1800"));
  sarKeyValVOS.add(new SarKeyValVO(2,"GSM 850"));
  sarKeyValVOS.add(new SarKeyValVO(3,"GSM 900"));
  
  List<SarKeyValVO> collect = sarKeyValVOS
  .stream()
  .sorted((o1, o2) -> compareString(o1.getBand(), o2.getBand()))
  .collect(Collectors.toList());
  
  System.out.println(Arrays.asList(collect));
  // {...GSM 850}, {...GSM 900}, {...GSM 1800}, {...GSM 1900}

http://www.kler.cn/news/234624.html

相关文章:

  • 【MySQL】-15 MySQL综合-1(数据库概念+数据库涉及技术)
  • 【数据结构】13:表达式转换(中缀表达式转成后缀表达式)
  • 【Java】悲观锁和乐观锁有什么区别?
  • 【java】笔记10:类与对象——本章练习
  • Leetcode 3033. Modify the Matrix
  • Spring + Tomcat项目中nacos配置中文乱码问题解决
  • 代码随想录算法训练营第39天(动态规划02● 62.不同路径 ● 63. 不同路径 II
  • 第二节 zookeeper基础应用与实战
  • 知识价值2-什么是IDE?新手用哪个IDE比较好?
  • python:lxml 读目录.txt文件,用 xmltodict 转换为json数据,生成jstree所需的文件
  • 寒假作业5
  • 基于python和matlab的复杂函数拟合的方法、工具以及学习资料
  • 【中间件学习】什么是中间件
  • 【Linux进程间通信】用管道实现简单的进程池、命名管道
  • [AIGC] Tomcat:一个简单 and 高效的 Java Web 服务器
  • 【设计模式】23中设计模式笔记
  • Hadoop:认识MapReduce
  • 【数据结构和算法】--- 基于c语言排序算法的实现(2)
  • Rust变量与常量介绍
  • vue-生命周期+工程化开发(三)
  • RCS系统之:机器人状态
  • 快速搭建 nfs 环境, 解决 nfs 搭建时的疑难杂症
  • C++STL速查手册
  • [NSSCTF]-Web:[SWPUCTF 2021 新生赛]easy_sql解析
  • 为什么IDM下载速度很慢,IDM下载速度很慢怎么办
  • FL Studio如何改变轨道颜色 FL Studio波形颜色如何自定义 flstudio21中文版下载 FL Studio 设置颜色
  • MySQL数据库-MVCC多版本并发控制
  • leetcode(矩阵)74. 搜索二维矩阵(C++详细解释)DAY7
  • 时序数据库Influxdb查询多个字段_field同一时间的值,组成一条数据
  • 【Git】三棵“树”介绍