160308java排序(形如1.11.2.1)

Posted 目标奔雷手

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了160308java排序(形如1.11.2.1)相关的知识,希望对你有一定的参考价值。

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;
}
}

以上是关于160308java排序(形如1.11.2.1)的主要内容,如果未能解决你的问题,请参考以下文章

java排序之冒泡排序

java排序之冒泡排序

java 数组排序的方法

java排序之冒泡排序

java排序,效率高的是哪种排序方法

数组排序-冒泡排序-插入排序-选择排序-Java实现