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

优惠网站怎么做大连网络建站模板

优惠网站怎么做,大连网络建站模板,怎么在运行打开wordpress,wordpress 您的主题支持1个菜单更新时间:2025-04-04 算法题解目录汇总:算法刷题记录——题解目录汇总技术博客总目录:计算机技术系列博客——目录页 优先整理热门100及面试150,不定期持续更新,欢迎关注! 226. 翻转二叉树 给你一棵二叉…

更新时间:2025-04-04

  • 算法题解目录汇总:算法刷题记录——题解目录汇总
  • 技术博客总目录:计算机技术系列博客——目录页

优先整理热门100及面试150,不定期持续更新,欢迎关注!


226. 翻转二叉树

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

示例 1:

输入:root = [4,2,7,1,3,6,9]
输出:[4,7,2,9,6,3,1]

示例 2:

输入:root = [2,1,3]
输出:[2,3,1]

示例 3:

输入:root = []
输出:[]

提示:

  • 树中节点数目范围在 [0, 100] 内
  • -100 <= Node.val <= 100

方法一:递归法

递归交换每个节点的左右子树,自顶向下逐层翻转。

代码实现(Java):

class Solution {public TreeNode invertTree(TreeNode root) {if (root == null) {return null;}// 交换当前节点的左右子节点TreeNode temp = root.left;root.left = root.right;root.right = temp;// 递归处理左右子树invertTree(root.left);invertTree(root.right);return root;}
}

方法二:广度优先搜索(BFS)

利用队列层序遍历,逐个节点交换左右子树。

代码实现(Java):

class Solution {public TreeNode invertTree(TreeNode root) {if (root == null) return null;Queue<TreeNode> queue = new LinkedList<>();queue.offer(root);while (!queue.isEmpty()) {TreeNode node = queue.poll();// 交换左右子节点TreeNode temp = node.left;node.left = node.right;node.right = temp;// 将子节点加入队列继续处理if (node.left != null) queue.offer(node.left);if (node.right != null) queue.offer(node.right);}return root;}
}

方法三:深度优先搜索(DFS)迭代法

使用栈模拟递归过程,前序遍历时交换左右子树。

代码实现(Java):

class Solution {public TreeNode invertTree(TreeNode root) {if (root == null) return null;Stack<TreeNode> stack = new Stack<>();stack.push(root);while (!stack.isEmpty()) {TreeNode node = stack.pop();// 交换左右子节点TreeNode temp = node.left;node.left = node.right;node.right = temp;// 将子节点压入栈(先右后左保证处理顺序)if (node.left != null) stack.push(node.left);if (node.right != null) stack.push(node.right);}return root;}
}

复杂度分析

  1. 递归法:从根节点开始,交换左右子节点,然后递归处理左右子树。每个节点只需处理一次,时间复杂度为 (O(n)),空间复杂度为 (O(h))(树的高度)。
  2. BFS迭代:借助队列层序遍历,每次处理节点时交换其左右子节点,并将子节点加入队列。时间复杂度 (O(n)),空间复杂度 (O(n))(最坏情况)。
  3. DFS迭代:使用栈实现深度优先遍历,处理节点时交换左右子节点。时间复杂度 (O(n)),空间复杂度 (O(h))(树的高度)。

230. 二叉搜索树中第 K 小的元素

给定一个二叉搜索树的根节点 root ,和一个整数 k ,请你设计一个算法查找其中第 k 小的元素(从 1 开始计数)。

示例 1:

输入:root = [3,1,4,null,2], k = 1
输出:1

示例 2:

输入:root = [5,3,6,2,4,null,null,1], k = 3
输出:3

提示:

树中的节点数为 n 。

  • 1 <= k <= n <= 10^4
  • 0 <= Node.val <= 10^4

进阶:
如果二叉搜索树经常被修改(插入/删除操作)并且你需要频繁地查找第 k 小的值,你将如何优化算法?


方法一:递归中序遍历(提前终止)

  • 利用中序遍历左-根-右的顺序天然有序的特点。
  • 遍历时对访问的节点计数,当计数达到k时记录结果并立即终止递归(通过返回值true提前退出递归栈)。
  • 剪枝优化,左子树找到目标后直接返回,避免无意义的右子树遍历。

代码实现(Java):

class Solution {private int count;private int result;public int kthSmallest(TreeNode root, int k) {count = k;inorder(root);return result;}private boolean inorder(TreeNode node) {if (node == null) return false;if (inorder(node.left)) return true;  // 左子树已找到目标if (--count == 0) {                   // 处理当前节点result = node.val;return true;                      // 找到目标,终止递归}return inorder(node.right);           // 继续遍历右子树}
}

方法二:迭代中序遍历(显式栈)

  • 用栈显式保存遍历路径,先深度优先遍历到最左节点。
  • 每次弹出栈顶元素时计数,找到第k个元素时直接返回。
  • 栈的深度为树高,避免递归栈溢出的风险。

代码实现(Java):

class Solution {public int kthSmallest(TreeNode root, int k) {Stack<TreeNode> stack = new Stack<>();TreeNode curr = root;int count = 0;while (curr != null || !stack.isEmpty()) {// 遍历到最左节点while (curr != null) {stack.push(curr);curr = curr.left;}// 回溯处理节点curr = stack.pop();if (++count == k) return curr.val; // 找到第k小的元素curr = curr.right;                // 转向右子树}return -1; // 题目保证k有效,此处不会执行}
}

复杂度分析

  • 时间复杂度:两种方法均为 O(k),最坏情况为 O(n)(当k=n时需要遍历整棵树)。
  • 空间复杂度:递归法 O(h)(h为树高),迭代法 O(h)(显式栈的空间占用)。

声明

  1. 本文版权归 CSDN 用户 Allen Wurlitzer 所有,遵循CC-BY-SA协议发布,转载请注明出处。
  2. 本文题目来源 力扣-LeetCode ,著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

文章转载自:

http://NwxUTSpu.qbdqc.cn
http://zv6EL7ov.qbdqc.cn
http://mm78hutr.qbdqc.cn
http://2SLiGpRP.qbdqc.cn
http://o1BgcJCF.qbdqc.cn
http://3JsejtV7.qbdqc.cn
http://0THgZset.qbdqc.cn
http://oJRCUdE5.qbdqc.cn
http://t5hqu1cK.qbdqc.cn
http://cjzjQdsW.qbdqc.cn
http://tCHvWjfx.qbdqc.cn
http://ysSurxNQ.qbdqc.cn
http://kguJWeF2.qbdqc.cn
http://c8hzcoA6.qbdqc.cn
http://ects0jqT.qbdqc.cn
http://CvF2jwc5.qbdqc.cn
http://GRpnnZy3.qbdqc.cn
http://qrJX1DAr.qbdqc.cn
http://pkjnZgMn.qbdqc.cn
http://wkyPuWOC.qbdqc.cn
http://0cWXvXUJ.qbdqc.cn
http://0BPnWH9T.qbdqc.cn
http://hdfHCkZZ.qbdqc.cn
http://0D9LgBus.qbdqc.cn
http://FPH9I9hQ.qbdqc.cn
http://7slyYOog.qbdqc.cn
http://XmIrcje1.qbdqc.cn
http://rRQTRct0.qbdqc.cn
http://dAUumpSY.qbdqc.cn
http://b6RQ3DF5.qbdqc.cn
http://www.dtcms.com/wzjs/669919.html

相关文章:

  • 温州网站建设方案推广wordpress 登录logo
  • 网站建设具体流程图进一步优化营商环境
  • 企业网站建设有哪些优势域名服务器分为
  • 如何查看网站是否被降权1m带宽做网站
  • 做电影网站要多少钱注册万维网网站
  • 方法数码做的网站怎么样数字重庆公司
  • 菏泽建设局网站wordpress给管理员发送邮件
  • ic电子网站建设建设网站费用计入什么科目
  • 个人域名 做公司网站网站 js 广告代码
  • 个人博客网站建设预算seo建站技术
  • 如何建设一个外卖订餐平台网站开发工具设置控件格式
  • 如何自建企业网站电竞logo免费设计
  • vr全景网站怎么做thinkphp建站网址
  • 雄安网站建设费用青岛网站设计流程
  • 做阿里巴巴网站找谁无极电影网在线观看完整版
  • 网站开发用什么编辑器网站建设的总体需求
  • 深圳网站建设q479185700強薪火相传网站建设
  • wordpress更换回编辑器抖音关键词排名优化
  • 建设网站的合约手机网站制作费用
  • 广东网站建设找汽车之家官网手机版网页
  • 返利网站开发一般要多少钱家具家居网站建设
  • 哪里有做网站的汕头免费建站哪里有
  • 设计色彩网站如何建立一个网站分享教程
  • dede小视频网站源码做断桥铝窗户的网站
  • 免费微信建站有哪些网站静安做网站公司
  • 社交网站建设流程做自己任务的网站
  • 松江建设管理中心网站wordpress 招商系统
  • 做餐饮类网站用哪个程序网站网页怎么压缩
  • 网站建设编程怎么写宝安网站设计案例
  • 专业的销售网站镇江丹徒发布