Java字符串排序中文和数字的方法

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

Java字符串排序中文和数字的方法
Java字符串排序中文和数字的方法
在Java中,排序需要复写的是 equals 方法和 Comparable 接口的public int compareTo(T o);。

下面是店铺为大家带来的Java字符串排序中文和数字的方法,欢迎阅读。

方法步骤:
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{
String name = null;
public OrderWrapper(String name){
= name;
}
public String getName() {
return name;
}
public void setName(String 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 == ){
return false;
} else {
return .equals();
}
}
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 = ;
String name2 = ;
// 特殊情形,name有一个为空的情况.
if(null == name1){
// 都为空,认为相对
if(null == name2){
return 0;
} else {
return -1;
}
} else if(null == name2){
return 1;
}
// 中间 1-多个数字
Pattern pattern = pile("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 pareTo();
}
public static void testNew(){
List chinesesOrderList = new ArrayList();
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();
}
}。

相关文档
最新文档