leetcode93复原 IP 地址刷题打卡

简介: leetcode93复原 IP 地址刷题打卡
93. 复原 IP 地址

有效 IP 地址 正好由四个整数(每个整数位于 0255 之间组成,且不能含有前导 0),整数之间用 '.' 分隔。

  • 例如:"0.1.2.201" "192.168.1.1"有效 IP 地址,但是 "0.011.255.245""192.168.1.312""192.168@1.1"无效 IP 地址。

给定一个只包含数字的字符串 s ,用以表示一个 IP 地址,返回所有可能的有效 IP 地址,这些地址可以通过在 s 中插入 '.' 来形成。你 不能 重新排序或删除 s 中的任何数字。你可以按 任何 顺序返回答案。

示例 1:

输入:s = "25525511135"
输出:["255.255.11.135","255.255.111.35"]

示例 2:

输入:s = "0000"
输出:["0.0.0.0"]

示例 3:

输入:s = "101023"
输出:["1.0.10.23","1.0.102.3","10.1.0.23","10.10.2.3","101.0.2.3"]

提示:

  • 1 <= s.length <= 20
  • s 仅由数字组成
题解思路

要用到的方法:

// string类的insert方法和erase方法
// 在迭代器所指位置前插入一个字符
s.insert(iterator it, char a);
// 在迭代器所指位置删除一个字符
s.erase(iterator it);
// 单个字符转换为数字
char a_char  = '1';
int a_int = a_char - '0';

思路:

本题是给定一个字符串,将其还原为IP地址,可以将其划为分割问题,分割问题就可以用回溯算法来穷举所有目标项

回溯就是递归,可以按照递归三步走

  • 确定函数的返回值和参数列表
  • 还原ip地址需要在字符串中加.这一元素,可以提供一个参数来统计点的个数
  • 这题肯定是不能重复元素分割,所以还要有一个startIndex来标记切割的起始位置。
  • 回溯无需返回值
  • 确定终止条件
  • 终止条件就可以利用pointerNumber,只有当pointerNumber达到了3才会进入终止条件,然后就顺其自然的查看最后一个点后的数是否合格来决定是否加入结果目录
if(pointNumber == 3){
    if(isValid(s, startIndex, s.size() - 1))
        result.push_back(s);
    return ;
}
  • 确定本层逻辑
  • 本层逻辑也就是回溯逻辑,根据模板,其通常都是一个for循环里面套一个递归,整个回溯可以抽象成一个树形结构,for循环遍历宽度,递归遍历深度。其他解释不了勒,成为高高手了在来描述,现在很难描述出来,
for(int i = startIndex; i < s.size(); i++){
    if(isValid(s, startIndex, i)){
        s.insert(s.begin() + i + 1, '.');
        pointNumber++;
        backtracking(s, i + 2, pointNumber);
        pointNumber--;
        s.erase(s.begin() + i + 1);
    }else break;
}

valid函数

  • 判断第四段子字符串是否合法,如果合法就放进result
  • 0开头的数字不合法
  • 遇到非数字字符不合法
  • 如果大于255了不合法
bool isValid(string s, int start, int end){
    if(start > end) return false;
    if(s[start] == '0' && start != end) return false;
    int sum = 0;
    for(int i = start; i <= end; i++){
        if(s[i] < '0' || s[i] > '9') return false;
        sum = sum * 10 + (s[i] - '0');
        if(sum > 255) return false;
    }
    return true;
}

完整代码

class Solution {
public:
    vector<string> result;
    bool isValid(string s, int start, int end){
        if(start > end) return false;
        if(s[start] == '0' && start != end) return false;
        int sum = 0;
        for(int i = start; i <= end; i++){
            if(s[i] < '0' || s[i] > '9') return false;
            sum = sum * 10 + (s[i] - '0');
            if(sum > 255) return false;
        }
        return true;
    }
    void backtracking(string s, int startIndex, int pointNumber){
        if(pointNumber == 3){
            if(isValid(s, startIndex, s.size() - 1))
                result.push_back(s);
            return ;
        }
        for(int i = startIndex; i < s.size(); i++){
            if(isValid(s, startIndex, i)){
                s.insert(s.begin() + i + 1, '.');
                pointNumber++;
                backtracking(s, i + 2, pointNumber);
                pointNumber--;
                s.erase(s.begin() + i + 1);
            }else break;
        }
    }
    vector<string> restoreIpAddresses(string s) {
        backtracking(s, 0, 0);
        return result;
    }
};


相关文章
|
1月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
38 6
|
1月前
|
Python
【Leetcode刷题Python】剑指 Offer 26. 树的子结构
这篇文章提供了解决LeetCode上"剑指Offer 26. 树的子结构"问题的Python代码实现和解析,判断一棵树B是否是另一棵树A的子结构。
34 4
|
1月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
64 2
|
27天前
|
算法
LeetCode第93题复原 IP 地址
文章介绍了LeetCode第93题"复原 IP 地址"的解法,利用回溯算法和剪枝技术,通过树形图分析求解过程,实现了将字符串分割成满足IP地址段要求的子段,并验证每个子段是否有效。
LeetCode第93题复原 IP 地址
|
1月前
|
索引 Python
【Leetcode刷题Python】从列表list中创建一颗二叉树
本文介绍了如何使用Python递归函数从列表中创建二叉树,其中每个节点的左右子节点索引分别是当前节点索引的2倍加1和2倍加2。
32 7
|
1月前
|
Python
【Leetcode刷题Python】剑指 Offer 30. 包含min函数的栈
本文提供了实现一个包含min函数的栈的Python代码,确保min、push和pop操作的时间复杂度为O(1)。
16 4
|
1月前
|
Python
【Leetcode刷题Python】剑指 Offer 22. 链表中倒数第k个节点
Leetcode题目"剑指 Offer 22. 链表中倒数第k个节点"的Python解决方案,使用双指针法找到并返回链表中倒数第k个节点。
39 5
|
1月前
|
算法 Python
【Leetcode刷题Python】 LeetCode 2038. 如果相邻两个颜色均相同则删除当前颜色
本文介绍了LeetCode 2038题的解法,题目要求在一个由'A'和'B'组成的字符串中,按照特定规则轮流删除颜色片段,判断Alice是否能够获胜,并提供了Python的实现代码。
36 3
|
1月前
|
算法 Python
【Leetcode刷题Python】剑指 Offer 33. 二叉搜索树的后序遍历序列
本文提供了一种Python算法,用以判断给定整数数组是否为某二叉搜索树的后序遍历结果,通过识别根节点并递归验证左右子树的值是否满足二叉搜索树的性质。
14 3
|
1月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - II. 从上到下打印二叉树 II
本文提供了一种Python实现方法,用于层次遍历二叉树并按层打印结果,每层节点按从左到右的顺序排列,每层打印到一行。
28 3