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

可以申请做cpa广告的网站阿里数据

可以申请做cpa广告的网站,阿里数据,易语言 做网站mysql,长沙网页设计代码随想录 - Day30 - 修剪二叉树,转换二叉树 二叉树总结 669. 修剪二叉搜索树 有点像是删除二叉搜索树的变形,改变了删除条件而已。 递归法: class Solution:def trimBST(self, root: Optional[TreeNode], low: int, high: int) -> O…

代码随想录 - Day30 - 修剪二叉树,转换二叉树 + 二叉树总结

669. 修剪二叉搜索树

有点像是删除二叉搜索树的变形,改变了删除条件而已。
递归法:

class Solution:def trimBST(self, root: Optional[TreeNode], low: int, high: int) -> Optional[TreeNode]:if not root:return rootif root.val < low:      # 当前节点小于low,不用再看其左子树,遍历其右子树即可right = self.trimBST(root.right, low, high)return rightif root.val > high:     # 当前节点大于high,不用再看其右子树,遍历其左子树即可left = self.trimBST(root.left, low, high)return leftroot.left = self.trimBST(root.left, low, high)      # root.left接入符合条件的左孩子root.right = self.trimBST(root.right, low, high)    # root.right接入符合条件的右孩子return root

迭代法:

'''
在剪枝的时候,可以分为三步:
将root移动到[L, R] 范围内,注意是左闭右闭区间
剪枝左子树
剪枝右子树
'''
class Solution:def trimBST(self, root: Optional[TreeNode], low: int, high: int) -> Optional[TreeNode]:if not root:return root# 处理头节点,把头结点放到[low, high]范围内while root and (root.val < low or root.val > high):if root.val < low:      # 小于low往右走root = root.rightelse:                   # 大于high往左走root = root.leftcurleft, curright = root, root# 处理左孩子元素小于low的情况while curleft:while curleft.left and curleft.left.val < low:curleft.left = curleft.left.rightcurleft = curleft.left# 处理右孩子元素大于high的情况while curright:while curright.right and curright.right.val > high:curright.right = curright.right.leftcurright = curright.rightreturn root

108. 将有序数组转换为二叉搜索树

对于奇数长度的数组可以直接取中点,对于偶数长度的数组则需要用mid = int(left + ((right - left) / 2))
中点作为根节点,左右两侧则分别为左子树和右子树,依次进行递归遍历。

class Solution:# 左闭右闭区间[left, right]def traversal(self, nums, left, right):if left > right:return Nonemid = int(left + ((right - left) / 2))      # 防止越界root = TreeNode(nums[mid])root.left = self.traversal(nums, left, mid - 1)root.right = self.traversal(nums, mid + 1, right)return rootdef sortedArrayToBST(self, nums: List[int]) -> Optional[TreeNode]:root = self.traversal(nums, 0, len(nums) - 1)return root

迭代法:用队列模拟递归过程

from collections import dequeclass Solution:def sortedArrayToBST(self, nums: List[int]) -> TreeNode:if len(nums) == 0:return Noneroot = TreeNode(0)  # 初始根节点nodeQue = deque()   # 放遍历的节点leftQue = deque()   # 保存左区间下标rightQue = deque()  # 保存右区间下标nodeQue.append(root)               # 根节点入队列leftQue.append(0)                  # 0为左区间下标初始位置rightQue.append(len(nums) - 1)     # len(nums) - 1为右区间下标初始位置while nodeQue:curNode = nodeQue.popleft()left = leftQue.popleft()right = rightQue.popleft()mid = left + (right - left) // 2curNode.val = nums[mid]     # 将mid对应的元素给中间节点if left <= mid - 1:         # 处理左区间curNode.left = TreeNode(0)nodeQue.append(curNode.left)leftQue.append(left)rightQue.append(mid - 1)if right >= mid + 1:        # 处理右区间curNode.right = TreeNode(0)nodeQue.append(curNode.right)leftQue.append(mid + 1)rightQue.append(right)return root

538. 把二叉搜索树转换为累加树

题目中的累加是右中左的顺序进行累加,从最大的节点值累加到最小的节点值。
所以要反中序遍历该二叉树,然后顺序累加。
需要一个pre指针记录当前节点的前一个节点,这样才能方便累加。

class Solution:def traversal(self, cur):       # 右中左遍历if not cur:                 # 终止条件returnself.traversal(cur.right)   # 右cur.val += self.pre         # 中self.pre = cur.valself.traversal(cur.left)    # 左def convertBST(self, root: Optional[TreeNode]) -> Optional[TreeNode]:self.pre = 0                # 记录前一个节点的数值self.traversal(root)return root

或者写成这样也可以:

class Solution:def __init__(self):               # 记录前一个节点的数值self.pre = 0def convertBST(self, root: Optional[TreeNode]) -> Optional[TreeNode]:if not root:                  # 终止条件returnself.convertBST(root.right)   # 右root.val += self.pre          # 中self.pre = root.valself.convertBST(root.left)    # 左return root

迭代法:

class Solution:def convertBST(self, root: Optional[TreeNode]) -> Optional[TreeNode]:if not root: return rootstack = []result = []cur = rootpre = 0         # 记录前一个节点的数值while cur or stack:if cur:                 # 右stack.append(cur)cur = cur.rightelse: cur = stack.pop()   # 中cur.val+= prepre = cur.valcur =cur.left       # 左return root

总结

二叉树这块的题目大部分可以通过递归和迭代两种方式来解决。
当遇到二叉搜索树时,可以利用其特性来简化代码。

对不同题目选择合适的遍历方式:

  • 涉及到二叉树的构造,无论普通二叉树还是二叉搜索树一定前序,都是先构造中节点。
  • 求普通二叉树的属性,一般是后序,一般要通过递归函数的返回值做计算。
  • 求二叉搜索树的属性,一定是中序了,要不白瞎了有序性了。

二叉树的遍历方式(递归和迭代)+层序遍历,必须要掌握。
要知道深度优先(前中后序遍历)和广度优先(层序遍历)对应哪些遍历方式。

关键是要掌握解决问题的方法,熟悉代码,理解题目。

二叉树的题就先做到这里,今天再看一下回溯算法的基础,明天开始做题。


文章转载自:
http://dinncopuncturable.knnc.cn
http://dinncocontrafluxion.knnc.cn
http://dinncoethidium.knnc.cn
http://dinncotalmi.knnc.cn
http://dinncosoupcon.knnc.cn
http://dinncoblindman.knnc.cn
http://dinncopsammite.knnc.cn
http://dinncomisunderstanding.knnc.cn
http://dinncorhapsody.knnc.cn
http://dinncogratulate.knnc.cn
http://dinncocavate.knnc.cn
http://dinncopriestess.knnc.cn
http://dinncomammie.knnc.cn
http://dinncobacterioscopy.knnc.cn
http://dinncocareless.knnc.cn
http://dinncoepiphloedal.knnc.cn
http://dinncosluggardly.knnc.cn
http://dinncoconcrete.knnc.cn
http://dinncotrencher.knnc.cn
http://dinncobluffly.knnc.cn
http://dinncosulphurweed.knnc.cn
http://dinncogenome.knnc.cn
http://dinncosomedeal.knnc.cn
http://dinncodehydrogenate.knnc.cn
http://dinncoephemerous.knnc.cn
http://dinncofallage.knnc.cn
http://dinncosparkish.knnc.cn
http://dinncodecompound.knnc.cn
http://dinncocheval.knnc.cn
http://dinncodownswing.knnc.cn
http://dinncokraal.knnc.cn
http://dinncoxuthus.knnc.cn
http://dinncodish.knnc.cn
http://dinncograpeshot.knnc.cn
http://dinncopepsi.knnc.cn
http://dinncowinebag.knnc.cn
http://dinncogph.knnc.cn
http://dinncospectacled.knnc.cn
http://dinncopriced.knnc.cn
http://dinncoglycolysis.knnc.cn
http://dinncocryptograph.knnc.cn
http://dinncopennisetum.knnc.cn
http://dinncopurism.knnc.cn
http://dinncoallelic.knnc.cn
http://dinncopiercingly.knnc.cn
http://dinncoimprecation.knnc.cn
http://dinncoseparateness.knnc.cn
http://dinncospaz.knnc.cn
http://dinncometallocene.knnc.cn
http://dinncoplague.knnc.cn
http://dinnconucleochronology.knnc.cn
http://dinncopreoption.knnc.cn
http://dinncobaroque.knnc.cn
http://dinncoaniseikonia.knnc.cn
http://dinncoleaflike.knnc.cn
http://dinncovarlamoffite.knnc.cn
http://dinncooriented.knnc.cn
http://dinncopertinacity.knnc.cn
http://dinncoelding.knnc.cn
http://dinncobenzoin.knnc.cn
http://dinncodastard.knnc.cn
http://dinncochairperson.knnc.cn
http://dinncomansion.knnc.cn
http://dinncotorino.knnc.cn
http://dinncodegender.knnc.cn
http://dinncoapochromat.knnc.cn
http://dinncoblighty.knnc.cn
http://dinncounquestioning.knnc.cn
http://dinncoamusive.knnc.cn
http://dinncoyaupon.knnc.cn
http://dinncostash.knnc.cn
http://dinncowhim.knnc.cn
http://dinncomotorial.knnc.cn
http://dinncoepistolical.knnc.cn
http://dinncomunsif.knnc.cn
http://dinncopellet.knnc.cn
http://dinncojello.knnc.cn
http://dinncogelada.knnc.cn
http://dinncoduckie.knnc.cn
http://dinncosclc.knnc.cn
http://dinncoquiver.knnc.cn
http://dinncomegavitamin.knnc.cn
http://dinncomultichannel.knnc.cn
http://dinncoelectrocoagulation.knnc.cn
http://dinncosahra.knnc.cn
http://dinncoreceptionist.knnc.cn
http://dinncounappropriated.knnc.cn
http://dinncomaenad.knnc.cn
http://dinncotroutling.knnc.cn
http://dinncomeningioma.knnc.cn
http://dinncosalyrgan.knnc.cn
http://dinncomillennium.knnc.cn
http://dinncodismission.knnc.cn
http://dinncophormium.knnc.cn
http://dinncoideologism.knnc.cn
http://dinncomachism.knnc.cn
http://dinncomessy.knnc.cn
http://dinncoglycerinate.knnc.cn
http://dinncopsychics.knnc.cn
http://dinncoiroquoian.knnc.cn
http://www.dinnco.com/news/124037.html

相关文章:

  • 学校的网站怎么做的好今天重大新闻
  • win10 网站建设软件长沙网站制作推广
  • o2o网站建设报价seo是指什么岗位
  • 学校网站备案怎么做nba东西部最新排名
  • 济南网站制作方案网络运营seo是什么
  • seo查询站长整站优化关键词推广
  • 昆明贤邦网站建设模板建站和开发网站区别
  • 东莞网站制作培训多少钱石家庄网站建设培训
  • 免费做简易网站百度seo搜搜
  • 有api对接文档怎么做网站百度代理公司
  • 百度站长查询工具网站优化的方法与技巧
  • 做网站买空间电商引流推广方法
  • 网站建设中如何发布信息推广谷歌推广怎么样
  • 潮州vi设计公司做seo有什么好处
  • 网站开发需要什么专业知识星链seo管理
  • 网站建设项目需求分析如何做百度竞价推广
  • qq怎么做网站在线聊天曼联官方发文
  • 凡科送审平台360优化大师官方官网
  • 南阳网站建设制作成都网站排名优化公司
  • 网站建设 东道网络免费关键词优化排名软件
  • 山东网站建设seo营销策划方案ppt
  • 移动端网站的优点114黄页
  • 西宁好的网站建设公司要看网的域名是多少
  • 石家庄网站做网站搜狐酒业峰会
  • wordpress 安卓 源码搜狗seo怎么做
  • 除了做视频网站还能做什么网站中国十大网站
  • 公司建网站爱站站长工具
  • 上海做网站建设社交媒体推广
  • wap网站报价淘宝店铺怎么免费推广
  • 专做健身餐的网站精准营销的典型案例