/*
* 【练习2】
* 对ip地址排序:
* 192.168.10.34 127.0.0.1 3.3.3.3 105.70.11.55
*/
package test2;
import java.util.TreeSet;
public class Test2 {
public static void main(String[] args) {
String str_ip = "192.168.10.34 127.0.0.1 3.3.3.3 105.70.11.55";
/*
* 1.为了让ip可以按照字符串顺序比较,只要让ip的每一段的位数相同,所以补零,
* 每一段都加两个0.
*/
String regex = "(\\d+)";//将所有连着的数字组成一组,可以一个数字也可以多个数字,所以+
str_ip = str_ip.replaceAll(regex, "00$1");//$1用于获取组,之后在前面补两0
//2.每一段数字保留3位
String regex2 = "0*(\\d{3})";
/*
* 第一步之后每段肯定0开头,所以0*表示没有0或者有多个0,\\d{3}表示连续3位数字,(\\d{3})表示将连续3个数字编成一组
*/
str_ip = str_ip.replaceAll(regex2, "$1");//用该组去替换每一段数字
//3.用TreeSet进行排序
String regex3 = " +";//一个或多个空格
String[] ips = str_ip.split(regex3);
TreeSet<String> ts = new TreeSet<String>();
for(String ip : ips){
ts.add(ip);
}
for(String ip : ts){
//4.将每段数字前面的0去除
String regex4 = "0*(\\d+)";
System.out.println(ip.replaceAll(regex4, "$1"));
}
}
}
/*
* 【运行结果】
* 3.3.3.3
* 105.70.11.55
* 127.0.0.1
* 192.168.10.34
*/
28-正则表达式-08-正则表达式(练习_2)
最新推荐文章于 2024-07-03 23:09:46 发布