北大硕士LeetCode算法专题课--递归和回溯

news2024/12/25 9:00:27

 算法专题课





北大硕士LeetCode算法专题课-栈、队列相关问题_骨灰级收藏家的博客-CSDN博客

北大硕士LeetCode算法专题课--链表相关问题_骨灰级收藏家的博客-CSDN博客

北大硕士LeetCode算法专题课-查找相关问题_骨灰级收藏家的博客-CSDN博客

北大硕士LeetCode算法专题课-字符串相关问题_骨灰级收藏家的博客-CSDN博客

北大硕士LeetCode算法专题课-数组相关问题_骨灰级收藏家的博客-CSDN博客

北大硕士LeetCode算法专题课-基础算法查找_骨灰级收藏家的博客-CSDN博客

北大硕士LeetCode算法专题课-基础算法之排序_骨灰级收藏家的博客-CSDN博客

北大硕士LeetCode算法专题课---算法复杂度介绍_骨灰级收藏家的博客-CSDN博客

二叉树简

二叉树(Binary Tree) 是一种树形数据结构,其中每个父节点最多可以有两个子节点。 二叉树的每个节点(node)包含三个属性:

data 数据

left 左子节点的地址

right 右子节点的地址

满二叉树(Full Binary Tree)每个结点要么没有子结点,要么有两个子结点

 

完美二叉树(Pefect Binary Tree)每个结点都有两个子结点,所有叶子结点都在同一层

完全二叉树(Complete Binary Tree)从根结点到倒数第二层为完美二叉树,最后一层可以不完全填充,其叶子结点都靠左对齐

 

二叉树天然的具有递归结构,二叉树的递归定义为:二叉树是一棵空树,或者是一棵由一个根节点和两棵互不相交的,  分别称作根的左子树和右子树组成的非空树;左子树和右子树又同样都是二叉树

 

 

二叉树的遍历方

LeetCode 题目中,二叉树的遍历方式是最基本,也是最重要的一类题目。先介绍一下二叉树的遍历方式。

先序遍历(前序遍历):按照根节点 -> 左孩子 -> 右孩子 的方式遍历,即「先序遍历」,每次先遍历根节点,  遍历结果为 1 2 4 5 3 6 7

 

LeetCode 题目中,二叉树的遍历方式是最基本,也是最重要的一类题目。先介绍一下二叉树的遍历方式。 中序遍历:按照左孩子 -> 根节点 -> 右孩子 的方式遍历,即「中序序遍历」

遍历结果为 4 2 5 1 6 3 7

LeetCode 题目中,二叉树的遍历方式是最基本,也是最重要的一类题目。先介绍一下二叉树的遍历方式。 后序遍历:按照左孩子 -> 右孩子 -> 根节点 的方式遍历,即「后序序遍历」

遍历结果为 4 5 2 6 7 3 1

LeetCode 144.二叉树的前序遍历 输出结果 [1,2,4,5,3,6]

 

def preorderTraversal2(root):  res = list()
if not root:
return res

stack = []  node = root
while stack or node:
while node:
res.append(node.val)  stack.append(node)  node = node.left
node = stack.pop()  node = node.right
return res

二叉树的遍历解题方法- 迭代使用

LeetCode 144.二叉树的前序遍历 输出结果 [1,2,4,5,3,6,7]

def preorderTraversal2(root):  res = list()
if not root:
return res

stack = []  node = root
while stack or node:
while node:
res.append(node.val)  stack.append(node)  node = node.left
node = stack.pop()  node = node.right
return res

二叉树的遍历解题方

LeetCode 102 中等.二叉树的层序遍历,使用队列

输出结果 [[1], [2, 3], [4, 5, 6, 7]]

 

二叉树的最大深度 (LeetCode 104)

给定一个二叉树,找出其最大深度。

二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。 说明: 叶子节点是指没有子节点的节点。

如果我们知道了左子树和右子树的最大深度 l r,那么该二叉树的最大深度即为 max(l,r)+1

 

如果我们知道了左子树和右子树的最大深度 l r,那么该二叉树的最大深度即为 max(l,r)+1

def maxDepth(root):  if root is None:
return 0
else:
left_height = maxDepth(root.left)  right_height = maxDepth(root.right)  return max(left_height, right_height) + 1

复杂度分析

时间复杂度O(n) ,其中 n 为二叉树节点的个数。每个节点在递归中只被遍历一次。 空间复杂度O(height) ,其中 height表示二叉树的高度。递归函数需要栈空间,而栈空 间取决于递归的深度,因此空间复杂度等价于二叉树的高度。

翻转二叉 (LeetCode 226)

给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。

给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。

 给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。 

def invertTree(root):
# 递归终止条件,节点为空时返回
if not root:
return None
# 递归调用
left = invertTree(root.left)  right = invertTree(root.right)
# 将当前节点的左右子树交换 root.left, root.right = right, left  return root

复杂度分析:时间复杂度:O(n) 空间复杂度:O(n)

路径总 (LeetCode 112)

给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。判断该树中是否存在 根节点到叶子节点 的路径,  这条路径上所有节点值相加等于目标和 targetSum 。如果存在,返回 true ;否则,返回 false

叶子节点 是指没有子节点的节点。

输入root = [5,4,8,11,null,13,4,7,2,null,null,null,1], targetSum = 22

输出true

解释:等于目标和的根节点到叶节点路径如上图所示。

使用递归的思路解决问题的时候, 需要注意递归的终止条件。

class Solution(object):
def hasPathSum(self, root, targetSum):  """
:type root: TreeNode
:type targetSum: int
:rtype: bool  """
if not root:
return targetSum == 0
if self.hasPathSum(root.left, targetSum - root.val):
return True
if self.hasPathSum(root.right, targetSum - root.val):
return True
return False

 使用递归的思路解决问题的时候, 需要注意递归的终止条件。下面写法中的递归终止条件考虑并不全面,  当输入为[], targetSum = 0 时, 下面的解法会返回True 但实际上应该是False

class Solution(object):
def hasPathSum(self, root, targetSum):  """
:type root: TreeNode
:type targetSum: int
:rtype: bool  """
if not root:
return targetSum == 0
if self.hasPathSum(root.left, targetSum - root.val):
return True
if self.hasPathSum(root.right, targetSum - root.val):
return True
return False

电话号码的字母组 (LeetCode 17)

给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。 给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

给给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。 给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

 

digits 是数字字符串, s(digits) digits 所能代表的字母字符串

s(digits[0…n-1]) = letter(digits[0]) + s(digits[1…n-1]) = letter(digits[0]) + letter(digits[1]) + s(digits[2…n-1])

复杂度分析

时间复杂度O(3n) (O(2n))

空间复杂度O(m+n)

回溯

回溯法也称试探法,它的基本思想是:

从问题的某一种状态(初始状态)出发,搜索从这种状态出发所能达到的所有“状态”,

当一条路走到“尽头”的时候(不能再前进),再后退一步或若干步,从另一种可能“状态”出发,继续搜索 直到所有的“路径”(状态)都试探过

这种不断“前进”、不断“回溯”寻找解的方法,就称作“回溯法”

回溯法是暴力解法的一个主要手段

全排 (LeetCode 46)

给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。

 

 

def permute(nums):
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

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/157706.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一.【linux】常用操作命令

目录 1 . 查看当前登录系统用户信息 【who】 2 . 查看终端用户whoami 3 . 查看日期date 4 . 查看系统信息uname 5 . 日历cal 6 . 计算器bc 8 . 显示或修改计算机主机名的命令hostname 9 . 在显示器上显示文字的命令echo 10 . 清除计算机屏幕上的信息命令clear 11 . 查…

【尚硅谷】Java数据结构与算法笔记04 - 栈

文章目录一、实际需求二、栈的介绍三、应用场景四、数组模拟栈4.1 思路分析4.2 Java代码实现五、栈实现综合计算器5.1 中缀表达式5.2 后缀表达式一、实际需求 二、栈的介绍 栈的英文为(stack)栈是一个先入后出(FILO-First In Last Out)的有序列表。栈(stack)是限制线性表中元素…

nacos 2.1.0集群生产环境多节点部署

nacos 2.1.0集群生产环境多节点部署 版本 2.1.0版本发布日期 2022-04-29官网 集群部署说明GitHub GitHub - alibaba/nacos: an easy-to-use dynamic service discovery, configuration and service management platform for building cloud native applications. 下载地址&…

大数据面试题(七):Flume核心高频面试题

文章目录 Flume核心高频面试题 一、Flume有哪些组件,flume的source、channel、sink具体是做什么的 二、你是如何实现flume数据传输的监控的 三、Flume的source,sink,channel的作用?你们source是什么类型? 四、Flu…

2023年浙江建筑施工电工(建筑特种作业)模拟试题及答案

百分百题库提供特种工(电工)考试试题、特种工(电工)考试真题、特种工(电工)证考试题库等,提供在线做题刷题,在线模拟考试,助你考试轻松过关。 159.临时⽤电⼯程验收应填写&#xff0…

基于Vue 全家桶实现网易云音乐 WebApp

基于 Vue(2.5) vuex vue-router vue-axios better-scroll Scss ES6 等开发一款移动端音乐 WebApp,UI 界面参考了安卓版的网易云音乐、flex 布局适配常见移动端。因为服务器的原因,所以可能多人访问的时候有些东西会加载不出来,如果可以的…

P2069 松鼠吃果子

题目描述 输入输出样例 输入 #1 10 4 输出 #1 9 说明/提示 注:吃掉的果子依次为 3,8,5(回到下面重做第 3 跳),9(回到下面重做第 4 跳)。 写着感觉好别扭 感觉和字符串没啥关…

接口管理工具YApi怎么用?颜值高、易管理、超好用!

众多接口管理工具如雨后春笋搬冒出。让人欣慰的是,有许多优秀作品来自国内,包含YApi和rap。 看着中文的官网,熟悉的汉语,不禁让人暗爽。当然这也就带来另一个弊端,因为使用基数少,所以参考资料少。我们想学…

发送tcp/udp请求

本文章介绍下通过nc工具和iperf工具,发送tcp/udp请求一、nc工具(netcat工具)这个工具linux系统默认是自带的,以下是命令的常用参数1.1 发送tcp请求在服务端监听端口nc -l port客户端连接并发送请求nc -v host port在服务端收到了信…

自定义动态IRule进行路由转发

gateway的负载均衡以及feign服务之间的调用或者RestTemplate请求,都可以使用自定义IRule规则进行路由转发。 自定义IRule 固定IRule:将IRule的一个实现类注入到spring容器中 Configuration public class MyIRuleConfig { Beanpublic IRule myIRule() {…

力扣sql基础篇(五)

力扣sql基础篇(五) 1 页面推荐 1.1 题目内容 1.1.1 基本题目信息 1.1.2 示例输入输出 a 输入示例 b 输出示例 1.2 示例sql语句 # Write your MySQL query statement below SELECT distinct page_id recommended_page FROM Likes WHERE (user_id in (SELECT user2_idFROM …

字符串查找、错误信息、字符分类函数

1、寻找子串strstr char* my_strstr(const char* str1, const char* str2) {assert(str1 && str2);const char* cp str1;const char* s1 str1;const char* s2 str2;while (*cp){s2 str2;s1 cp;while (*s1!\0 && *s2!\0 && * s1 *s2){s1;s2;}if (…

一步一步学爬虫(5)Ajax分析方法

一步一步学爬虫(5)Ajax分析方法5.2.1. 分析案例5.2.2. 过滤请求5.2.3. 总结5.2.1. 分析案例 这里还需要借助浏览器的开发者工具,下面以 Chrome 浏览器为例来介绍。 首先,用 Chrome 浏览器打开微博的链接 https://m.weibo.cn/u/283…

排查开机启动项

防止被控机器失联部分木马会添加开机启动项作为复活的手段 /etc/rc.local /etc/rc.local 是 /etc/rc.d/rc.local的软链接 [rootVM-4-11-centos etc]# ll rc.local lrwxrwxrwx 1 root root 13 Apr 6 2022 rc.local -> rc.d/rc.localrc.local的原始内容: #!/…

中文文案排版指北

格式规范千千万,内容创作 No.1 但是当下我们专注与文案排版。优秀的排版、正确使用标点符号能让阅读者赏心悦目,提升阅读体验。这篇文章将 GitHub 上的有关排版的规范摘抄部分供大家查阅,更多详情还请访问原文所在(底部引用中的地…

APSIM练习:小麦苜蓿轮作

在本练习中,您将创建一个小麦苜蓿轮作,其中草料阶段持续数年。 基于“Rotation Sample.apsim”创建一个新的模拟。这是小麦鹰嘴豆轮作。在 Manager 文件夹中,Rotation Management 组件用于表示旋转,使用带有节点(圆圈…

网站需要怎么优化比较好(网站优化有哪些技巧)

怎样让网站优化在短时间内看到效果? 在企业推广营销推广中,网站优化占据了很大一部分,对于企业推广营销有着决定性影响。如果想让您的企业在诸多品牌中脱颖而出,甚至在互联网中有强大的竞争力,你必须要做好网站优化&a…

基于微信小程序云开发的投票小程序源码,图文投票微信小程序源码

功能介绍 投票活动十分火,商家,企业,机构偶尔都会来一场投票活动评选,本小程序支持图文投票,简单方便、随时随地完成投票,可以方便设定投票模式(按天按全程,投票数限定)…

MySQL基础——DQL语句

select 聚合函数(字段列表) from 表名; Mysql的相关知识 好处 : 1.持久化数据到本地 2.可以实现结构化查询,方便管理 数据库主要分为: DB(数据库),保存一系列有组织的数据容器。 DBMS(数据库管理系统),用于对DB获得数…

[蓝桥杯 2017 省 B] k 倍区间(前缀和枚举/数论优化)

题目传送门 思路分析: 第一思路比较容易想到,就是枚举所有的前缀和,然后遍历它们计数满足题意的前缀和数量,最后输出即可,但是这里的数列最多达到了100000,在2层循环下,总的枚举次数就达到了O(…