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<String> 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<String> restoreIpAddresses(String s) {
        result=new ArrayList<String>();
        if(s.length()<1)
            return result;
        digits=s.toCharArray();
        for(int i=0;i<s.length();i++)
            digits[i]-='0';
        find(0,digits[0],""+(int)(digits[0]),1);
        return result;
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值