码迷,mamicode.com
首页 > 编程语言 > 详细

160308、java排序(形如1.1、1.2.1)

时间:2016-03-08 13:20:20      阅读:195      评论:0      收藏:0      [点我收藏+]

标签:

package com.rick.sample;
 
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
 
public class SortUtilDemo {
 
public static void sortIdentify(List<String> lists){
SortComparator sortComparator = new SortComparator();
Collections.sort(lists, sortComparator);
}
 
public static void main(String[] args) {
ArrayList<String> lists = new ArrayList<String>();
lists.add("1.1");
lists.add("1.2");
lists.add("1.2.1");
lists.add("3.1.2");
lists.add("2.6.6");
lists.add("2.6.3");
lists.add("1.10.1");
lists.add("1.10.2");
lists.add("1.10.1.2");
lists.add("1.1.1");
lists.add("10.1.1");
 
sortIdentify(lists);
 
for (String ids : lists) {
System.out.println(ids);
}
}
}
 
/**
 * 重写排序接口
 * @author Administrator
 */
class SortComparator implements Comparator<String>{
@Override
public int compare(String pre, String suf) {
String[] preArrs = pre.split("\\.");
String[] sufArrs = suf.split("\\.");
int len = preArrs.length > sufArrs.length ? preArrs.length : sufArrs.length;
for (int i = 0; i < len; i++) {
int preNum = 0;
int sufNum = 0;
 
if (i < preArrs.length) {
preNum = Integer.parseInt(preArrs[i]);
}
 
if (i <sufArrs.length) {
sufNum = Integer.parseInt(sufArrs[i]);
}
 
if (preNum > sufNum) {
return 1;
} else if(preNum < sufNum){
return -1;
}
return 0;
}
}

160308、java排序(形如1.1、1.2.1)

标签:

原文地址:http://www.cnblogs.com/zrbfree/p/5253650.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!