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

Java字符串排序中文+数字的更多相关文章

  1. java字符串排序(数字,字母,汉字等组合排序)

    package cn.cnnho.backstage.utils; import java.util.ArrayList;import java.util.Arrays;import java.uti ...

  2. java 字符串排序

    http://bbs.csdn.net/topics/280032929 大可不需要那样复杂了!(一)如果要排序的为字符串,如:String sortStr = "ACDFE";  ...

  3. 【JavaScript】冒泡排序,字符串排序,数字排序

    原理:是临近的数字两两进行比较,按照从小到大或者从大到小的顺序进行交换, function bubbleClick() { var str = "50,1,4,6,9,76,43,22,2, ...

  4. Java——字符串排序

    import java.util.ArrayList; import java.util.Collections; import java.util.List; public class Test { ...

  5. JAVA 统计字符串中中文,英文,数字,空格的个数

    面试题:输入一行字符,分别统计出其中英文字母.中文字符.空格.数字和其它字符的个数 可以根据各种字符在Unicode字符编码表中的区间来进行判断,如数字为'0'~'9'之间,英文字母为'a'~'z'或 ...

  6. JAVA 统计字符串中中文,英文,数字,空格,特殊字符的个数

    引言 可以根据各种字符在Unicode字符编码表中的区间来进行判断,如数字为'0'~'9'之间,英文字母为'a'~'z'或'A'~'Z'等,Java判断一个字符串是否有中文是利用Unicode编码来判 ...

  7. 使用Java正则表达式提取字符串中的数字一例

    直接上代码: String reg = "\\D+(\\d+)$"; //提取字符串末尾的数字:封妖塔守卫71 == >> 71 String s = monster. ...

  8. 利用TreeSet给纯数字字符串排序

    import java.util.Iterator;import java.util.TreeSet; /* * 给字符串中的数字排序 * String str = "10,2,11,1,3 ...

  9. SqlServer按中文数字排序

    表数据: 按名称排序 并不能得到一二三四五六的顺序 select * from LiWei order by name 找到中文数字在'一二三四五六七八九十'的位置 select id,name,SU ...

随机推荐

  1. CI引入外部javascript和css

    假定baseurl 为 $config['base_url']='http://localhost/codeigniter/'; 调用 <link rel="stylesheet&qu ...

  2. cocos2d-x中的尺寸之一

    cocos2d-x中的尺寸函数繁多,官方文档对各种尺寸没有很好的描述,网上文章更加寥寥,对尺寸和位置的理解如果不到位,写代码就非常困难,需要猜测尝试,效率低下.这个文章我将研究一些我所迷惑的尺寸函数, ...

  3. 使用Boost.Asio编写通信程序

    摘要:本文通过形像而活泼的语言简单地介绍了Boost::asio库的使用,作为asio的一个入门介绍是非常合适的,可以给人一种新鲜的感觉,同时也能让体验到asio的主要内容. Boost.Asio是一 ...

  4. android LinearLayout和RelativeLayout实现精确布局

    先明确几个概念的区别: padding margin:都是边距的含义,关键问题得明白是什么相对什么的边距padding:是控件的内容相对控件的边缘的边距. margin  :是控件边缘相对父空间的边距 ...

  5. 【C++学习笔记】继承与派生基础概念

    面向对象的程序设计主要有四个特点:抽象.封装.继承和多态.其中继承是我认为最最重要的一个特性,可以说继承是面向对象的精华所在. 举一个继承的浅显易懂的例子:假如我们已经有了一个“马”的类,其中成员变量 ...

  6. Spring MVC遭遇checkbox的问题解决方式

    Spring MVC遭遇checkbox的问题是:当checkbox全不选时候,则该checkbox域的变量为null,不能动态绑定到spring的controller方法的入參上,并抛出异常. 解决 ...

  7. SPOJ LCS(Longest Common Substring-后缀自动机-结点的Parent包含关系)

    1811. Longest Common Substring Problem code: LCS A string is finite sequence of characters over a no ...

  8. python下yield(生成器)

    python下的协程: #encoding=utf-8 """ 协程----微小的进程 yield生成器-----生成一个可迭代对象比如list, tuple,dir 1 ...

  9. 如何隐藏DLL中,导出函数的名称?

    一.引言 很多时候,我们写了一个Dll,不希望别人通过DLL查看工具,看到我们的导出函数名称.可以通过以下步骤实现: 1. 在def函数中做如下定义: LIBRARY EXPORTS HideFunc ...

  10. JavaScript基础知识----基本语法

    JavaScript 语句 JavaScript 语句向浏览器发出的命令.语句的作用是告诉浏览器该做什么. 分号 ; 分号用于分隔 JavaScript 语句. 通常我们在每条可执行的语句结尾添加分号 ...