LintCode 恢复IP地址

题目

给一个由数字组成的字符串。求出其可能恢复为的所有IP地址。

样例
给出字符串 "25525511135",所有可能的IP地址为:

[
"255.255.11.135",
"255.255.111.35"
]
(顺序无关紧要)

分析

方法一:
直接三种循环暴力求解

public class Solution {
    /**
     * @param s the IP string
     * @return All possible valid IP addresses
     */
    public ArrayList restoreIpAddresses(String s) {
        ArrayList res = new ArrayList();
        int len = s.length();
        for(int i = 1; i<4 && i3 || s.length()==0 || (s.charAt(0)=='0' && s.length()>1) || Integer.parseInt(s)>255)
            return false;
        return true;
    }
}

方法二:
深度搜索,回溯

public class Solution {
    /**
     * @param s the IP string
     * @return All possible valid IP addresses
     */
    public ArrayList restoreIpAddresses(String s) {
        ArrayList result = new ArrayList();
        ArrayList list = new ArrayList();
        
        if(s.length() <4 || s.length() > 12)
            return result;
        
        helper(result, list, s , 0);
        return result;
    }
    
    public void helper(ArrayList result, ArrayList list, String s, int start){
        if(list.size() == 4){
            if(start != s.length())
                return;
            
            StringBuffer sb = new StringBuffer();
            for(String tmp: list){
                sb.append(tmp);
                sb.append(".");
            }
            sb.deleteCharAt(sb.length()-1);
            result.add(sb.toString());
            return;
        }
        
        for(int i=start; i= 0 && digit <= 255;
    }
}

你可能感兴趣的:(LintCode 恢复IP地址)