当前位置: 首页 > news >正文

【力扣hot100】刷题笔记Day17

前言

  • 今天竟然不用开组会!天大的好消息,安心刷题了

46. 全排列 - 力扣(LeetCode)

  • 回溯(排列)

    • class Solution:def permute(self, nums: List[int]) -> List[List[int]]:# 回溯def backtrack():if len(path) == len(nums):res.append(path[:])  # 如果path长度达到要求,收集结果,注意python要拷贝resreturn for i in range(len(nums)):if used[i] == 0:  # 遍历所有没用过的used[i] = 1path.append(nums[i])backtrack()path.pop()  # 撤销used[i] = 0  # 撤销# 可变对象在函数中可以直接改不需要作为参数,也不需要写self,只有赋值需要# 比如:递归里self.res= max(self.res,l+r)需要用self或递归里nonlocal res声明n = len(nums)used = [0] * npath = []res = []backtrack()return res
  • 回溯(交换填充)

    • class Solution:def permute(self, nums: List[int]) -> List[List[int]]:def backtrack(first = 0):# 所有数都填完了if first == n:  res.append(nums[:])for i in range(first, n):# 动态维护数组nums[first], nums[i] = nums[i], nums[first]# 继续递归填下一个数backtrack(first + 1)# 撤销操作nums[first], nums[i] = nums[i], nums[first]n = len(nums)res = []backtrack()return res

 78. 子集 - 力扣(LeetCode)

  • 回溯(组合)

    • class Solution:def subsets(self, nums: List[int]) -> List[List[int]]:def backtrack(start=0):res.append(path[:])  # 每到一个节点就传一次答案# if start == n: return  # 下面的for循环隐含这个终止条件for i in range(start, n):path.append(nums[i])backtrack(i+1)  # 注意这里传入的是i+1path.pop()n = len(nums)res = []path = []backtrack(0)return res
      

17. 电话号码的字母组合 - 力扣(LeetCode) 

  • 回溯(不同集合的组合)

    • class Solution:def letterCombinations(self, digits: str) -> List[str]:def backtrack(index = 0):if index == len(digits):res.append("".join(path))  # 不用传复制因为已经新建字符串了returns = mp[int(digits[index])]  # 取出对应数字的字符串for c in s:path.append(c)backtrack(index+1)path.pop()if len(digits) == 0:return []mp = ['', '', 'abc', 'def', 'ghi', 'jkl', 'mno', 'pqrs', 'tuv', 'wxyz']  # 下标号码映射字符串path = []res = []backtrack()return res

39. 组合总和 - 力扣(LeetCode) 

  • 回溯(排序剪枝)

    • class Solution:def combinationSum(self, candidates: List[int], target: int) -> List[List[int]]:path = []res = []n = len(candidates)def backtrack(start, target):if target < 0: return    # 剪枝返回上一层,后面更大的数就没必要减了if target == 0:res.append(path[:])returnfor i in range(start, n):path.append(candidates[i])backtrack(i, target-candidates[i])  # 传i而不是i+1说明当前数可以重复选path.pop()candidates.sort()  # 剪枝,排序后大的数在后面选择优先级低backtrack(0, target)return res

 22. 括号生成 - 力扣(LeetCode)

  • 回溯(组合)

    • 这个题解结合官解就能看懂了,主要在于括号合法性判断上
    • class Solution:def generateParenthesis(self, n: int) -> List[str]:if n <= 0: return nres = []def backtrack(path, left, right):# 两种情况需要剪枝# 1.左括号多于n了:((((# 2.右括号多于左括号:())if left > n or right > left: returnif len(path) == 2 * n:  # 因为括号都是成对出现的res.append(path)returnbacktrack(path + '(', left + 1, right)  # 生成一个加一个backtrack(path + ')', left, right + 1)backtrack('', 0, 0)return res

后言

  • 今天就到这吧,还有其他事情,感觉回溯还不熟练,脑子里模拟不太出来,待会去看看代码随想录再熟悉熟悉 

http://www.lryc.cn/news/309040.html

相关文章:

  • leetcode日记(34)通配符匹配
  • 一张图读懂人工智能
  • 5.37 BCC工具之uflow.py解读
  • R语言简介,R语言开发环境搭建步骤,R基础语法以及注释详解
  • 【Django】执行查询—检索对象
  • Python:练习:编写一个程序,写入一个美金数量,然后显示出如何用最少的20美元、10美元、5美元和1美元来付款
  • 模板方法模式 详解 设计模式
  • Node.js_基础知识(http模块)
  • matlab工具包
  • UCSF DOCK 分子对接详细案例(01)- rigid, fixed anchor, flexible dock
  • java基础(4)注解,集合,
  • 基于springboot+vue的大学城水电管理系统(前后端分离)
  • 代码随想录算法训练营第四十六天| 139.单词拆分、卡码网第56题
  • Redis 在 Linux 系统下安装部署的两种方式详细说明
  • 【茶话数据结构】查找最短路径——Dijkstra算法详解(保姆式详细图解,步步紧逼,保你学会)
  • Webserver解决segmentation fault(core dump)段错问问题
  • 存储过程基本了解
  • 『大模型笔记』RAG应用的12种调优策略指南
  • leedcode刷题--day7(字符串)
  • 【蓝桥杯省赛真题31】python连续正整数之和 中小学青少年组蓝桥杯比赛python编程省赛真题解析
  • 【116个】网络安全测试相关面试真题
  • 微服务day02-Ribbon负载均衡与Nacos安装与入门
  • 深度学习-神经网络原理
  • Chat GPT:智能对话的下一步
  • [数据集][目标检测]鸡蛋破蛋数据集VOC+YOLO格式792张2类别
  • RabbitMQ实战学习
  • 插混、油混、增程式、轻混、强混,啥区别
  • React 模态框的设计(八)优化补充
  • 知识积累(三):深度学习相关概念(查看检索时看到)
  • 计算机专业必看的几部电影