Java字符串排序中文+数字

简介: 编写日期: 2013年9月15日 另一中解法:点击查看 解决思路: 在Java中,排序需要复写的是 equals 方法 和 Comparable 接口 的public int compareTo(T o); 方法 步骤: 1. 使用正则表达式来判断数字,多个连续的数字作为一组, 2.  一次检索出数字组合, 3. 检出下一组数字,如果有,则进入步骤4,否则进入步骤6. 4. 如果两组数字出现的位置相等,并且前面部分的字符串相等,则进入第5步。

编写日期: 2013年9月15日

另一中解法:点击查看

解决思路: 在Java中,排序需要复写的是 equals 方法 和 Comparable<T> 接口 的public int compareTo(T o); 方法

步骤:

1. 使用正则表达式来判断数字,多个连续的数字作为一组,

2.  一次检索出数字组合,

3. 检出下一组数字,如果有,则进入步骤4,否则进入步骤6.

4. 如果两组数字出现的位置相等,并且前面部分的字符串相等,则进入第5步。否则break,跳到第6步.

5. 如果前面部分的字符串完全一致。则比较两个数字的大小,如果大小一致,则进入下一组,即步骤3.如果大小不一致,则可以比对出来大小,比较结束

6. 调用String的compareTo方法,病返回(流程结束)。

完整的代码如下:

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

//包装器类
public class OrderWrapper implements Comparable<OrderWrapper>{
	String name = null;
	public OrderWrapper(String name){
		this.name = name;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	
	@Override
	public String toString() {
		return String.valueOf(name);
	}
	@Override
	public boolean equals(Object obj) {
		if(obj == this){
			return true;
		} 
		
		if(obj instanceof OrderWrapper){
			OrderWrapper other = (OrderWrapper)obj;
	
			if(null == this.name){
				return false;
			} else {
				return this.name.equals(other.name);
			}
		}
		return false;
	}

	// 比较方法,相当于减法。 (return this - wrapper)
	public int compareTo(OrderWrapper wrapper) {
		if(null == wrapper){
			return 1;
		}
		// 直接相等
		if(this == wrapper || this.equals(wrapper)){
			return 0;
		}
		String name1 = this.name;
		String name2 = wrapper.name;
		// 特殊情形,name有一个为空的情况.
		if(null == name1){
			// 都为空,认为相对
			if(null == name2){
				return 0;
			} else {
				return -1;
			}
		} else if(null == name2){
			return 1;
		}
		// 中间 1-多个数字
		Pattern pattern = Pattern.compile("\\D*(\\d+)\\D*");
		Matcher matcher1 = pattern.matcher(name1);
		Matcher matcher2 = pattern.matcher(name2);
		//System.out.println(pattern.pattern());
		//
		int index1_step = 0;
		int index2_step = 0;
		while(matcher1.find()){
			String s1 = matcher1.group(1);
			String s2 = null;
			if(matcher2.find()){
				s2 = matcher2.group(1);
			}
			int index1 = name1.indexOf(s1, index1_step);
			int index2 = name2.indexOf(s2, index2_step);
			//
			index1_step = index1;
			index2_step = index2;
			// 索引相等的情况下
			if(index1 == index2){
				System.out.println("name1="+name1.length()+"\nname2="+name2.length());
				System.out.println("index1="+index1+",index2="+index2);
				String pre1 = name1.substring(0, index1);
				String pre2 = name2.substring(0, index2);
				if(pre1.equals(pre2)){
					// 
					long num1 = Long.parseLong(s1);
					long num2 = Long.parseLong(s2);
					//
					if(num1 == num2){
						// 比较下一组
						continue;
					} else {
						return (int)(num1 - num2);
					}
				} else {
					break;
				}
			} else {
				break;
			}
		}
		
		// 最后的情形.
		return this.name.compareTo(wrapper.name);
	}
	

	public static void testNew(){
		List<OrderWrapper> chinesesOrderList = new ArrayList<OrderWrapper>();  
        chinesesOrderList.add(new OrderWrapper("我们80后相亲奇遇记-1.mp3"));  
        chinesesOrderList.add(new OrderWrapper("他80后相亲奇遇记-10.mp3"));  
        chinesesOrderList.add(new OrderWrapper("我80后相亲奇遇记-11.mp3"));  
        chinesesOrderList.add(new OrderWrapper("啊80后相亲奇遇记-12.mp3"));  
        chinesesOrderList.add(new OrderWrapper("我80后相亲奇遇记-13.mp3"));  
        chinesesOrderList.add(new OrderWrapper("我80后相亲奇遇记-25.mp3"));  
        chinesesOrderList.add(new OrderWrapper("我80后相亲奇遇记-26.mp3"));  
        chinesesOrderList.add(new OrderWrapper("我80后相亲奇遇记-2.mp3"));  
        chinesesOrderList.add(new OrderWrapper("我80后相亲奇遇记-3.mp3"));  
        chinesesOrderList.add(new OrderWrapper("我80后相亲奇遇记-4.mp3"));  
        chinesesOrderList.add(new OrderWrapper("a80后相亲奇遇记-4.mp3"));  
   
        //Collator collatorChinese = Collator.getInstance(java.util.Locale.CHINA);  
        //collatorChinese = Collator.getInstance(java.util.Locale.CHINESE);  
       // Collections.sort(chinesesOrderList, collatorChinese);  
        Collections.sort(chinesesOrderList);  

        System.out.println("中文+数字排序: = ");  
        for (int i = 0; i < chinesesOrderList.size(); i++) {  
        	OrderWrapper chinese = chinesesOrderList.get(i);  
            System.out.println("" + chinese);  
        }  

	}
	
	public static void main(String[] args) {
		testNew();
	}
}


目录
相关文章
|
1月前
|
存储 缓存 安全
Java 字符串详解
本文介绍了 Java 中的三种字符串类型:String、StringBuffer 和 StringBuilder,详细讲解了它们的区别与使用场景。String 是不可变的字符串常量,线程安全但操作效率较低;StringBuffer 是可变的字符串缓冲区,线程安全但性能稍逊;StringBuilder 同样是可变的字符串缓冲区,但非线程安全,性能更高。文章还列举了三者的常用方法,并总结了它们在不同环境下的适用情况及执行速度对比。
72 17
|
1月前
|
存储 缓存 安全
Java字符串缓冲区
字符串缓冲区是用于处理可变字符串的容器,Java中提供了`StringBuffer`和`StringBuilder`两种实现。由于`String`类不可变,当需要频繁修改字符串时,使用缓冲区更高效。`StringBuffer`是一个线程安全的容器,支持动态扩展、任意类型数据转为字符串存储,并提供多种操作方法(如`append`、`insert`、`delete`等)。通过这些方法,可以方便地对字符串进行添加、插入、删除等操作,最终将结果转换为字符串。示例代码展示了如何创建缓冲区对象并调用相关方法完成字符串操作。
51 13
|
5月前
|
SQL Java 索引
java小工具util系列2:字符串工具
java小工具util系列2:字符串工具
195 83
|
3月前
|
Java 程序员
Java 排序神器:Comparable 和 Comparator 该怎么选?
嗨,大家好,我是小米!今天和大家聊一聊Java社招面试中常考的经典问题——Comparable和Comparator的区别。Comparable定义对象的自然排序,适用于单一固定的排序规则;Comparator则是策略接口,用于定义自定义排序规则,适用于多样化或多变的排序需求。掌握这两者的区别是理解Java排序机制的基础,也是面试中的加分题。结合实际项目场景深入探讨它们的应用,能更好地打动面试官。如果你觉得有帮助,欢迎点赞、收藏、分享,期待你的一键三连!我们下期见~ 我是小米,一个喜欢分享技术的程序员,关注我的微信公众号“软件求生”,获取更多技术干货!
59 20
|
5月前
|
存储 安全 Java
Java零基础-字符串详解
【10月更文挑战第18天】Java零基础教学篇,手把手实践教学!
137 60
|
5月前
|
Java 数据库
java小工具util系列1:日期和字符串转换工具
java小工具util系列1:日期和字符串转换工具
112 26
|
5月前
|
存储 缓存 安全
java 中操作字符串都有哪些类,它们之间有什么区别
Java中操作字符串的类主要有String、StringBuilder和StringBuffer。String是不可变的,每次操作都会生成新对象;StringBuilder和StringBuffer都是可变的,但StringBuilder是非线程安全的,而StringBuffer是线程安全的,因此性能略低。
177 8
|
5月前
|
缓存 算法 Java
本文聚焦于Java内存管理与调优,介绍Java内存模型、内存泄漏检测与预防、高效字符串拼接、数据结构优化及垃圾回收机制
在现代软件开发中,性能优化至关重要。本文聚焦于Java内存管理与调优,介绍Java内存模型、内存泄漏检测与预防、高效字符串拼接、数据结构优化及垃圾回收机制。通过调整垃圾回收器参数、优化堆大小与布局、使用对象池和缓存技术,开发者可显著提升应用性能和稳定性。
110 6
|
6月前
|
Java 数据库
案例一:去掉数据库某列中的所有英文,利用java正则表达式去做,核心:去掉字符串中的英文
这篇文章介绍了如何使用Java正则表达式从数据库某列中去除所有英文字符。
148 15
|
6月前
|
Java
JAVA易错点详解(数据类型转换、字符串与运算符)
JAVA易错点详解(数据类型转换、字符串与运算符)
104 4