这道题就是说,有一个IP地址“ABC.EFG.HIJ.KML”的形式,把他的点去了(0则不显示),得到一个类似于ABCDEFGHI的形式,问说这个ABCDEFGHI实际上可以解析成几种IP地址的格式。
这道题其实就是回溯了,IP地址的判断规则是:
{
每一段都必须有数字,数字在0~255之间
一共四段数字
}
按照这个规则去检索和判断就可以了
Given a string containing only digits, restore it by returning all possible valid IP address combinations.
For example:
Given “25525511135”,
return [“255.255.11.135”, “255.255.111.35”]. (Order does not matter)
public class Solution {
List result;
char[] digits;
/**
* 回溯,为了加快速度可以提前计算下是否可行
* */
public void find(int part,int value,String tmp,int index){
if(part >3 || index>=digits.length){
if(part == 3 && index==digits.length){
result.add(tmp);
}
return ;
}
if(value*10+digits[index]<=255 && value!=0){
find(part,value*10+digits[index],tmp+(int)digits[index],index+1);
}
find(part+1,digits[index],tmp+"."+(int)digits[index],index+1);
}
public List restoreIpAddresses(String s) {
result=new ArrayList();
if(s.length()<1)
return result;
digits=s.toCharArray();
for(int i=0;i'0';
find(0,digits[0],""+(int)(digits[0]),1);
return result;
}
}