【Day21】LeetCode:93. 复原IP地址,78. 子集,90. 子集 II

文章目录

  • [LeetCode:93. 复原IP地址](#LeetCode:93. 复原IP地址)
  • [LeetCode:78. 子集](#LeetCode:78. 子集)
  • [LeetCode:90. 子集 II](#LeetCode:90. 子集 II)

LeetCode:93. 复原IP地址

https://leetcode.cn/problems/palindrome-partitioning/description/

思路

  1. 从当前起始位置开始,分别截取长度为1、2、3的子串。
  2. 检查该子串是否是一个合法的 IP 段。
  3. 如果合法,则将其加入 path ,并递归处理剩下的字符串和剩下的段数。
  4. 当已经得到四个段并且正好用完了整个字符串时,就找到了一个有效 IP 地址,将其加入结果。

解答

python 复制代码
class Solution:
    def restoreIpAddresses(self, s: str) -> List[str]:
        results = []
        path = []
        n = len(s)

        if n < 4 or n > 12: # 长度不符合,必然无法组成IP
            return results

        def backtrack(start: int, remain: int): # remain表示剩余几段
            if n - start < remain or n - start > 3 * remain: # 剩余长度不符合要求
                return

            if remain == 0 and start == n: # 已分割四段、且字符用完
                results.append(".".join(path))
                return
                        
            for length in range(1, 4): # 分别截取长度为1, 2, 3的子串
                if start + length > n:
                    break
                sub_s = s[start:start+length]
                
                if length > 1 and sub_s[0] == '0': # 前导零
                    continue
                
                if int(sub_s) > 255: # 超过范围
                    continue
                
                path.append(sub_s)
                backtrack(start + length, remain - 1)
                path.pop()

        backtrack(0, 4)
        return results

LeetCode:78. 子集

https://leetcode.cn/problems/subsets/

解答

python 复制代码
class Solution:
    def subsets(self, nums: List[int]) -> List[List[int]]:
        n = len(nums)
        results = []
        path = []

        def backtrack(start: int):
            results.append(path[:])
                
            for end in range(start, n):
                path.append(nums[end])
                backtrack(end + 1)
                path.pop()

        backtrack(0)
        return results

LeetCode:90. 子集 II

https://leetcode.cn/problems/subsets-ii/description/

思路

首先对数组进行排序,后续同一层的递归中,如果遇到元素相同则跳过。

解答

python 复制代码
class Solution:
    def subsetsWithDup(self, nums: List[int]) -> List[List[int]]:
        nums.sort() # 排序,方便后续去重
        n = len(nums)
        results = []
        path = []

        def backtrack(start):
            results.append(path[:])

            for i in range(start, n):
                if i > start and nums[i] == nums[i-1]: # 同一层递归中,如果当前元素与前一个相同,跳过
                    continue

                path.append(nums[i])
                backtrack(i + 1)
                path.pop()
    
        backtrack(0)
        return results
相关推荐
2501_921649493 分钟前
原油期货量化策略开发:历史 K 线获取、RSI、MACD 布林带计算到多指标共振策略回测
后端·python·金融·数据分析·restful
真心喜欢你吖7 分钟前
统信操作系统UOS部署安装OpenClaw+飞书接入完整教程(国产大模型配置)
人工智能·python·语言模型·大模型·openclaw·小龙虾
沉鱼.4414 分钟前
第十三届题目
c语言·c++·算法
用户83562907805114 分钟前
使用 Python 自动生成 Excel 柱状图的完整指南
后端·python
xcbrand16 分钟前
口碑好的品牌策划厂家
大数据·人工智能·python
ZHOU_WUYI22 分钟前
ppo算法简单实现
人工智能·pytorch·算法
liu****27 分钟前
LangChain-AI应用开发框架(七)
人工智能·python·langchain·大模型应用·本地部署大模型
hhcgchpspk29 分钟前
网速上传下载流量监测工具尝试
网络·python·cmd·psutil
飞Link1 小时前
大模型时代的“语言编程”:Prompt Engineering (提示词工程) 深度解析与实战指南
开发语言·python·prompt
无限进步_1 小时前
【C++】巧用静态变量与构造函数:一种非常规的求和实现
开发语言·c++·git·算法·leetcode·github·visual studio