leetcode 93 复原IP地址

简介: leetcode 93 复原IP地址

复原IP地址


4bd65c6c621f47b2a3314f1944502b9c.png和131回文串类似

class Solution {
public:
    vector<string> result;
    vector<string> path;
    //判断是合法IP
    bool cheak(string &s)
    {
        if(s.size()==0)return false;
        if(s.size() > 1 && s[0]=='0') return false;
        if (stoi(s) > 255) return false;
        return true;
    }
    void back_tracking(string &s , int indnx )
    {
      //IP最大短是4
        if(path.size() > 4)  return;
        //循环指针大于等于长度,并且IP段为四段。合法IP
        if(indnx >= s.size() && path.size()==4)
        {
            string tmp;
            for(int i=0 ;i< path.size()-1 ;i++)
            {
                tmp += path[i];
                tmp += '.';
            }
            tmp += path[path.size()-1];
            result.push_back(tmp);
            return;
        }
    //循环输入字符串,从index开始截取IP段
        for(int i=indnx ; i<s.size() ;i++)
        {
            string tmp;
            //截取一个IP段,但是不超过3位
            for(int j = indnx ; j<=i  &&  (j-indnx)<=3 ;j++)
            {
                tmp += s[j];
            }
      //检测是否为合法段,合法压入路径,不合法跳过该段
            if(cheak(tmp)==1) path.push_back(tmp);
            else continue;
      //递归
            back_tracking(s,i+1);
            //回溯
            path.pop_back();
        }
        return;
    }
    vector<string> restoreIpAddresses(string s) {
        back_tracking(s,0);
        return result;
    }
};

二刷

class Solution {
public:
    vector<string> result;
    vector<string> path;
    bool cheak(string s)
    {
        if(s.size() > 1 && s[0]=='0' || s.size() > 3) return false;
        int num = stoi(s);
        if(num > 255 || num <0) return false;
        return true;
    }
    void track_back(string s , int indnx)
    {
        if(path.size() > 4) return;
        if(indnx >= s.size() && path.size()==4) 
        {
            string tmp;
            for(int i=0 ; i<3 ;i++)
            {
                tmp += path[i];
                tmp += ".";
            }
            tmp += path[3];
            result.push_back(tmp);
        }
        for(int i= indnx ; i<s.size()&&i<indnx+3 ;i++)
        {   
            string tmp_ip = s.substr(indnx,i-indnx+1);
            if(cheak(tmp_ip) == false) continue;
            else
            {
                path.push_back(tmp_ip);
                track_back(s,i+1);
                path.pop_back();
            }
        }
    }
    vector<string> restoreIpAddresses(string s) {
        track_back(s,0);
        return result;
    }
};
相关文章
|
5月前
|
算法
代码随想录算法训练营第二十七天 | LeetCode 93. 复原 IP 地址、78. 子集、90. 子集 II
代码随想录算法训练营第二十七天 | LeetCode 93. 复原 IP 地址、78. 子集、90. 子集 II
34 0
|
6月前
|
算法
代码随想录Day23 回溯算法 LeetCode T93 复原ip地址 LeetCode T78子集 LeetCode T90 子集II
代码随想录Day23 回溯算法 LeetCode T93 复原ip地址 LeetCode T78子集 LeetCode T90 子集II
22 0
|
索引
LeetCode 93. Restore IP Addresses
给定一个用数字表示的字符串,把它们恢复成可能的IP地址.
41 0
LeetCode 93. Restore IP Addresses
LeetCode | 93. 复原 IP 地址
LeetCode | 93. 复原 IP 地址
70 0
代码随想录刷题|LeetCode 93.复原IP地址 78.子集 90.子集II
代码随想录刷题|LeetCode 93.复原IP地址 78.子集 90.子集II
|
存储 算法
LeetCode 92反转链表Ⅱ&93复制ip地址&94二叉树的中序遍历
反转从位置 m 到 n 的链表。请使用一趟扫描完成反转。
68 0
LeetCode 92反转链表Ⅱ&93复制ip地址&94二叉树的中序遍历
|
存储 算法
☆打卡算法☆LeetCode 93、复原 IP 地址 算法解析
“给定一个只包含整数的字符串,表示一个IP地址,返回所有可能有效的IP地址,在这些地址中插入点来形成。”
|
1月前
|
机器学习/深度学习 算法
力扣刷题日常(一)
力扣刷题日常(一)
20 2

热门文章

最新文章