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;
    }
};
相关文章
|
10月前
|
算法
leetcode93复原 IP 地址刷题打卡
leetcode93复原 IP 地址刷题打卡
59 0
|
10月前
|
Java
leetcode-93:复原 IP 地址
leetcode-93:复原 IP 地址
51 0
|
7月前
|
算法
LeetCode第93题复原 IP 地址
文章介绍了LeetCode第93题"复原 IP 地址"的解法,利用回溯算法和剪枝技术,通过树形图分析求解过程,实现了将字符串分割成满足IP地址段要求的子段,并验证每个子段是否有效。
LeetCode第93题复原 IP 地址
|
10月前
leetcode:1108. IP 地址无效化
leetcode:1108. IP 地址无效化
48 0
|
算法
代码随想录算法训练营第二十七天 | LeetCode 93. 复原 IP 地址、78. 子集、90. 子集 II
代码随想录算法训练营第二十七天 | LeetCode 93. 复原 IP 地址、78. 子集、90. 子集 II
74 0
|
算法
代码随想录Day23 回溯算法 LeetCode T93 复原ip地址 LeetCode T78子集 LeetCode T90 子集II
代码随想录Day23 回溯算法 LeetCode T93 复原ip地址 LeetCode T78子集 LeetCode T90 子集II
47 0
|
6月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
7月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
80 6
|
7月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
162 2
|
4月前
|
机器学习/深度学习 人工智能 自然语言处理
280页PDF,全方位评估OpenAI o1,Leetcode刷题准确率竟这么高
【10月更文挑战第24天】近年来,OpenAI的o1模型在大型语言模型(LLMs)中脱颖而出,展现出卓越的推理能力和知识整合能力。基于Transformer架构,o1模型采用了链式思维和强化学习等先进技术,显著提升了其在编程竞赛、医学影像报告生成、数学问题解决、自然语言推理和芯片设计等领域的表现。本文将全面评估o1模型的性能及其对AI研究和应用的潜在影响。
113 1