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

网站建设素材图苏州网站关键字优化

网站建设素材图,苏州网站关键字优化,wordpress怎么打删除线,为什么网站突然打不开从0开始的秋招刷题路,记录下所刷每道题的题解,帮助自己回顾总结 99. 恢复二叉搜索树 给你二叉搜索树的根节点 root ,该树中的 恰好 两个节点的值被错误地交换。请在不改变其结构的情况下,恢复这棵树 。 示例 1: 输入…

从0开始的秋招刷题路,记录下所刷每道题的题解,帮助自己回顾总结

99. 恢复二叉搜索树

给你二叉搜索树的根节点 root ,该树中的 恰好 两个节点的值被错误地交换。请在不改变其结构的情况下,恢复这棵树 。

示例 1:

在这里插入图片描述

输入:root = [1,3,null,null,2]
输出:[3,1,null,null,2]
解释:3 不能是 1 的左孩子,因为 3 > 1 。交换 1 和 3 使二叉搜索树有效。

示例 2:
在这里插入图片描述

输入:root = [3,1,4,null,null,2]
输出:[2,1,4,null,null,3]
解释:2 不能在 3 的右子树中,因为 2 < 3 。交换 2 和 3 使二叉搜索树有效。

提示:
树上节点的数目在范围 [2, 1000] 内
−231-2^{31}231 <= Node.val <= 231−12^{31} - 12311

进阶:使用 O(n) 空间复杂度的解法很容易实现。你能想出一个只使用 O(1) 空间的解决方案吗?

思路
因为只有两个节点错误,所以只要找出这两个节点然后交换值即可。

BST中序遍历是升序结果,因此进行中序遍历,使用三个指针指示节点,cur为当前节点,pre为当前节点之前的节点,wrongNode为错误节点

当当前节点小于上一个节点时,上一个节点pre就是第一个错误节点,用wrongNode记录,然后继续遍历,找出第二个错误节点, 这里有两种情况:

1.当当前节点大于wrongNode时,它的前节点就是第二个错误节点,如[1,3,2,4],错误节点分别为3、2

2.遍历结束时仍然没有节点大于wrongNode,则最后一个节点就是错误节点,如[3,1,2],错误节点为3、2

public void recoverTree(TreeNode root) {if (root == null) return;Stack<TreeNode> stack = new Stack<>();TreeNode pre = null, cur = root, wrongNode = null;while (!stack.isEmpty() || cur != null) {if (cur != null) {stack.add(cur);cur = cur.left;} else {cur = stack.pop();//与上一个节点比较,找到错误节点if (wrongNode == null && pre != null && cur.val < pre.val) {wrongNode = pre;}//表示当前节点是否大于wrongNodeif (wrongNode != null && cur.val > wrongNode.val) {swap(pre, wrongNode);break;}pre = cur;cur = cur.right;}}//如果没有节点大于wrongNode,与最后一个节点交换值if (wrongNode != null && wrongNode.val > pre.val) {swap(pre, wrongNode);}
}private void swap(TreeNode pre, TreeNode wrongNode) {int tmp = pre.val;pre.val = wrongNode.val;wrongNode.val = tmp;
}
http://www.15wanjia.com/news/18338.html

相关文章:

  • 网站建设资金的请示如何让百度搜索到自己的网站
  • 莆田网站建设公司学校网站建设哪家好
  • zblog做企业网站一手项目对接app平台
  • 成都管控政策最新消息百度搜索推广优化师工作内容
  • 新竹自助建站系统成都抖音seo
  • 山西长治做网站公司百度导航最新版本
  • 青岛科友网站建设网络公司头条指数
  • 婚介网站建设百度助手下载安装
  • 徐州网站建设网站制作seo课程培训中心
  • 网站做链接博客网站
  • 传统企业网站建设制作拓客引流推广
  • 做网站赚钱嘛seo网站推广方法
  • 微信移动网站建设灰色词秒收录代发
  • 做网站需要多少钱一个月百度账号一键登录
  • 长宁区网站建设网站济南新站seo外包
  • 描述对于营销型网站建设很重要飘红效果更佳廊坊网站设计
  • 做类似淘宝的网站开发需要什么查看今日头条
  • 谷歌网站的主要内容百度旗下推广平台有哪些
  • 网站建设与制作教程厦门seo俱乐部
  • error loading this resource wordpressseo学徒
  • 米读小说免费网站抢个总裁做爹地网站维护费一年多少钱
  • 成都网站建制作成都关键词seo推广平台
  • ubc网站谁做的各大网站提交入口
  • 建网站要什么小程序推广平台
  • 互联网营销是什么百度推广优化师
  • 做音乐网站的栏目济南网站运营公司
  • 具有价值的建网站推广之家app
  • 黄冈做网站价格2023年最新新闻简短摘抄
  • 电子游戏设计方案上海网站排名优化
  • 网站建设验收报告微信营销神器