Leetcode 93. Restore IP Addresses IP地址恢复 解题报告

1 解题思想

这道题就是说,有一个IP地址“ABC.EFG.HIJ.KML”的形式,把他的点去了(0则不显示),得到一个类似于ABCDEFGHI的形式,问说这个ABCDEFGHI实际上可以解析成几种IP地址的格式。

这道题其实就是回溯了,IP地址的判断规则是:
{
每一段都必须有数字,数字在0~255之间
一共四段数字
}

按照这个规则去检索和判断就可以了

2 原题

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)

3 AC解

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

你可能感兴趣的:(leetcode-java)