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

做综合类网站好不好百度网站官网入口

做综合类网站好不好,百度网站官网入口,上海 餐饮网站建设 会员系统,搜索引擎推广特点递归 递归三部曲: 1.确定参数和返回值2.确定终止条件3.确定单层逻辑 226.翻转二叉树 题目 思路与解法 第一想法: 递归,对每个结点进行反转 # Definition for a binary tree node. # class TreeNode: # def __init__(self, val0, le…

递归

递归三部曲:

  • 1.确定参数和返回值
  • 2.确定终止条件
  • 3.确定单层逻辑

226.翻转二叉树

题目

在这里插入图片描述

思路与解法

第一想法: 递归,对每个结点进行反转

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:def invertTree(self, root: Optional[TreeNode]) -> Optional[TreeNode]:cur = rootif cur:tmp = cur.leftcur.left = cur.rightcur.right = tmpself.invertTree(cur.left)self.invertTree(cur.right)return root

101. 对称二叉树

题目

在这里插入图片描述

思路与解法

carl的讲解:

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:def isSymmetric(self, root: Optional[TreeNode]) -> bool:if not root:return Truedef compare(left, right) -> bool:if not ((left and right) or (not left and not right)):return Falseif not left and not right:return Trueelif left.val != right.val:return Falseif not compare(left.left, right.right):return Falseif not compare(left.right, right.left):return Falsereturn Truereturn compare(root.left, root.right)

104.二叉树的最大深度

题目

在这里插入图片描述

思路与解法

第一思路: 可以用层序遍历,记录层数。递归的话就得想想了。不好描述,先写吧。
写了出来,在37/39个示例报超时。
在这里插入图片描述
发现超时的原因了,因为 16、17、18行的代码将get_depth(depth, node.left)get_depth(depth, node.right)各计算了两次。对于树这种递归结构,这是严重的性能问题
修改方式很简单,获取返回值后再比较就好:
在这里插入图片描述
**carl的讲解:**不再显示传递depth参数,因为递归本身隐式计算深度


class Solution:def maxDepth(self, root: Optional[TreeNode]) -> int:def get_depth(node: Optional[TreeNode]) -> int:if not node:return 0left_depth = get_depth(node.left)right_depth = get_depth(node.right)return 1 + max(left_depth, right_depth)return get_depth(root)

111.二叉树的最小深度

题目

在这里插入图片描述

思路与解法

第一想法: 就是简单的改前面的最大深度为最小深度。但是踩坑了,不是这么简单。
**carl的讲解:**因为最小深度的判别要比最大深度复杂。直接将max改成min是不行的,因为会把非叶子节点的值当作最小值返回。因为这个非叶子节点可能离根节点不愿,左边没节点但是右边有节点,这样他就可能得出的depth很小,但是他都不是叶子节点。

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:def minDepth(self, root: Optional[TreeNode]) -> int:return self.get_depth(root)def get_depth(self, node: Optional[TreeNode]) -> int:if not node:return 0left_depth = self.get_depth(node.left)right_depth = self.get_depth(node.right)if node.left is None and node.right is not None:return right_depth + 1if node.right is None and node.left is not None:return left_depth + 1return 1 + min(left_depth, right_depth) 
http://www.dtcms.com/wzjs/95934.html

相关文章:

  • 本地服务器如何做网站品牌定位
  • 网站用自己的电脑做服务器吗百度网盘在线登录
  • 网站建设在哪里办公湖南网络营销外包
  • 专门做投票的网站有哪些上海野猪seo
  • 太原网站建设的公司排名网络推广的方法和技巧
  • 男女一起做暖暖网站seo公司的选上海百首网络
  • 有那些网站可以做推广国家优化防控措施
  • 做电影网站犯法吗百度权重10的网站
  • zblog和wordpress有什么区别惠州seo公司
  • 国内免备案云主机seo综合查询怎么用的
  • WordPress分享到笔记广州优化疫情防控举措
  • 泉州台商区建设局网站产品软文是什么
  • xuzhou网站制作建站工具有哪些
  • 厦门同安网站制作企业软件开发公司
  • 使用oss做静态网站高清视频线和音频线的接口类型
  • 政府网站开发多钱网络建站工作室
  • wordpress2019谷歌字体电脑突然多了windows优化大师
  • 网站301跳转宁波网站制作与推广价格
  • 做网站兴趣爱好国内永久免费云服务器
  • 无线路由器做中继手机能连接但无法访问网站石家庄seo结算
  • 个人备案可以做企业网站吗深圳整站seo
  • 一级做爰片a视频网站推广引流话术
  • 建瓯市建设规划和旅游局网站免费做网站
  • 做网页链接网站自动交换友情链接
  • 响应式网站 做搜索推广缺点新闻今日头条最新消息
  • 苏州做企业网站公司建站为应用技术
  • 网站做支付端口的费用营销策划书模板
  • 网站服务器放置地百度权重怎么提高
  • 重庆网站建设师求职seo服务
  • 线上营销课程如何做seo整站优化