将字符串划分成ip地址,需要注意几点:
1、ip地址由四个整数组成;
2、每个整数的范围是[0,255];
3、四个整数通过逗号分隔符连接
4、每个整数除了它本身是0的情况之外,不能以0开头
我主要采用深度优先搜索+回溯的方法解决
对每一部分的整数的处理方式都是一样的,先取一位数,然后添加到临时要划分的ip字符串中,继续递归进行后面整数的划分,递归的过程中,如果划分出四个整数同时字符串又使用完毕,则组成了一种ip,否则就不是,直接返回。
public ArrayList<String> restoreIpAddresses (String s) {
// write code here
if (s == null || s.length() <= 3 || s.length() > 12){
return new ArrayList<>();
}
ArrayList<String> list = new ArrayList<>();
backTrace(0,s,list,new StringBuilder());
return list;
}
private void backTrace(int partNum, String s, List<String> list,StringBuilder midIp){
if (partNum == 4 || s.length() == 0){
if (partNum == 4 && s.length() == 0){
list.add(midIp.toString());
}
return;
}
for (int i = 0; i <= 2 && i < s.length(); i++) {
if (i != 0 && s.charAt(0) == '0'){
break;
}
String substring = s.substring(0, i + 1);
if (Integer.valueOf(substring) <= 255){
if (midIp.length() != 0){
substring = "." + substring;
}
midIp.append(substring);
backTrace(partNum+1,s.substring(i+1),list,midIp);
midIp.delete(midIp.length() - substring.length(),midIp.length());
}
}
}
京公网安备 11010502036488号