• Java字符串排序中文+数字


    编写日期: 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()+"
    name2="+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();
    	}
    }


  • 相关阅读:
    [转载][教程]vs2005入门 之 文件上传控件(FileUpLoad)[视频]
    .net 中使用Javacript弹出提示窗口方法总结
    创建分层行集的父表和子表之间的关系
    [转载][教程]vs2005控件演示之 Literal
    [转载][教程]母版页里面查找Repeater内控件(自动编号),并构造URL
    asp.net中的加密方法
    [转载][教程]vs2005/.NET2.0 控件演示之 文件上传 《FileUpload》 (二)
    [转][翻译]极好的ASP.NET2.0入门教程
    [原创]DATALIST 自定议翻页[支持模糊查询]
    六种异常处理的陋习(Java异常处理机制)——转载 Binary
  • 原文地址:https://www.cnblogs.com/lanzhi/p/6467095.html
Copyright © 2020-2023  润新知