leetCode.93. 复原 IP 地址

leetCode.93. 复原 IP 地址


题目思路:


代码

cpp 复制代码
// 前导零的判断方法:如果第一个数是0,且第二个数还有数据,那就是前导0,要排除的
// 注意跟单个 0 区分开
class Solution {
public:
    vector<string> res;
    vector<string> restoreIpAddresses(string s) {
        dfs( s, 0, 0, "" );
        return res;
    }

    // u = 遍历到第几个字符了, k = 遍历到第几个整数了,(我们要的只是四个整数)
    void dfs( string & s, int u, int k, string path ) {
        if ( s.size() == u ) {
            if ( k == 4) {
                // 去掉path最后面的.
                path.pop_back();
                res.push_back(path);
            }
            return;
        }

        // 特判一下,s 这个字符串给出的长度 远超过 12位,我们应该舍去
        // 标签的ip地址的上限位数是12位 ,k = 4的情况下,s.size() > 12,那就进行舍去接下来的遍历
        if ( k == 4) return;

        // t是记录当前的数据大小
        for ( int i = u, t = 0; i < s.size(); ++ i ) {
            if ( i > u && s[u] == '0') break; // 前导0

            t = t * 10 + s[i] - '0';
            if (t >= 0 && t <= 255) dfs( s, i + 1, k + 1, path + to_string(t) + '.');
            else break;
        }
    }
};
相关推荐
A22742 小时前
LeetCode 196, 73, 105
java·算法·leetcode
yachihaoteng6 小时前
Studying-代码随想录训练营day27| 贪心算法理论基础、455.分发饼干、376.摆动序列、53.最大子序和
c++·算法·leetcode·贪心算法
珂朵莉MM9 小时前
2024年马蹄杯专科组第三场初赛 解题报告 | 珂学家
java·开发语言·算法·leetcode·职场和发展
加冰老盐柠檬9 小时前
刷题之买股票的最佳时机(leetcode)
leetcode
千帐灯无此声11 小时前
力扣hot100 -- 贪心算法
算法·leetcode·贪心算法
硕风和炜12 小时前
【LeetCode:3101. 交替子数组计数 + 滑动窗口 + 数学公式】
java·数学·算法·leetcode·滑动窗口
danaaaa12 小时前
力扣刷题练习八【922. 按奇偶排序数组II】
数据结构·c++·算法·leetcode·职场和发展
青釉Oo12 小时前
数字流的秩
java·数据结构·算法·leetcode·二叉搜索树
当年拼却醉颜红12 小时前
力扣爆刷第159天之TOP100五连刷61-65(翻转单词、对称二叉树、遍历求和)
算法·leetcode·职场和发展
小字节,大梦想13 小时前
C语言_练习题
c语言·开发语言·数据结构·后端·算法·leetcode