day24 代码随想录 | 复原ip 地址 子集问题

复原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"]

这个题和切割字符串相似,只不过判断条件不一样。而且我们切割中止都是切割到末尾就可以结束了。此外,从题目的要求可以看到 s的长度应该在4-12之间,小于或大于这个长度就不可能完成满足条件的ip地址

回溯三部曲

  1. 回溯参数

字符串,startIndex,path, result

  1. 递归中止条件,就是startIndex== len(s) 并且你的path的长度为4了

  2. 单层搜索:

从startIndex 到 len(s)

判断是否符合ip要求

回溯模板

python 复制代码
class Solution:  # 剪枝
    def restoreIpAddresses(self, s: str) -> List[str]:
        path = []
        result = []
        self.backtracking(s, 0, path, result)
        return result

    def backtracking(self, s, startIndex, path, result):
        if startIndex == len(s) and len(path) == 4:
            result.append(".".join(path[:]))

        if len(path) > 4:
            return 

        for i in range(startIndex, min(startIndex+3, len(s)):
            if self.isValid(s, start, i+1):
                path.append(s[startIndex, i+1])
                self.backtracking(s, i+1, path, result)
                path.pop()
            else:
                continue


    def isValid(self, s, start, end):
        cut_s = s[start: end]
        if start > end:
            return False
        if cut_s[start] == "0" and len(cut_s) > 1:
            return False

        num = int(cut_s)
        if num < 0 or num > 255:
            return False

        return True

78.子集

给你一个整数数组 nums ,数组中的元素 互不相同 。返回该数组所有可能的

子集(幂集)。解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。

示例 1:

复制代码
输入:nums = [1,2,3]
输出:[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]

子集问题和前面的组合、分割问题都不相同。但是仍然可以用回溯解决。组合问题和分割问题我们都是要的叶子节点,而子集问题是要获取所有的节点

也是用回溯模板,但是我们一开始就可以收集结果了

中止条件就是如果startIndex走到最后了,就可以返回了

python 复制代码
class Solution:
    def subsets(self, nums: List[int]) -> List[List[int]]:
        path = []
        result = []
        self.backtracking(nums, 0, path, result)
        return result

    def backtracking(self, nums, startIndex, path, result):

        result.append(path[:]) # 直接收集

        if startIndex >= len(nums):
            return nums

        for i in range(startIndex, len(nums)):
            path.append(nums[i])
            self.backtracking(nums, i+1, path, result)
            path.pop()
            

90 子集II

给你一个整数数组 nums其中可能包含重复元素,请你返回该数组所有可能的

子集(幂集)。

解集 不能 包含重复的子集。返回的解集中,子集可以按 任意顺序 排列。

示例 1:

复制代码
输入:nums = [1,2,2]
输出:[[],[1],[1,2],[1,2,2],[2],[2,2]]

这个题的核心还是去重,跟之前的组合去重一样,是同层有重复元素去重,纵向的可以重复。

python 复制代码
class Solution:
    def subsetsWithDup(self, nums: List[int]) -> List[List[int]]:
        path = []
        result = []
        self.backtracking(nums, 0, path, result)
        return result

    def backtracking(self, nums, startIndex, path, result):
        result.append(path[:])

        if startIndex >= len(nums):
            return

        for i in range(startIndex, nums):
            if i > startIndex and nums[i-1] == nums[i]:
                    continue

            path.append(nums[i])
            self.backtracking(nums, i+1, path, result)
            path.pop()
相关推荐
xlp666hub4 分钟前
Leetcode第七题:用C++解决接雨水问题
c++·leetcode
Lupino11 分钟前
别再只聊 AI 写代码了:技术负责人要把“变更治理”提到第一优先级
python·docker·容器
CoovallyAIHub29 分钟前
CVPR 2026 | MixerCSeg:仅2.05 GFLOPs刷新四大裂缝分割基准!解耦Mamba隐式注意力,CNN+Transformer+Mamba三
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
YOLO26-Pose 深度解读:端到端架构重新设计,姿态估计凭什么跨代领先?
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
化工厂气体泄漏怎么用AI检测?30张图3D重建气体泄漏场景——美国国家实验室NeRF新研究
深度学习·算法·计算机视觉
Flittly2 小时前
【从零手写 ClaudeCode:learn-claude-code 项目实战笔记】(6)Context Compact (上下文压缩)
python·agent
曲幽12 小时前
FastAPI + PostgreSQL 实战:从入门到不踩坑,一次讲透
python·sql·postgresql·fastapi·web·postgres·db·asyncpg
颜酱13 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
用户83562907805117 小时前
使用 C# 在 Excel 中创建数据透视表
后端·python
zone773918 小时前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试