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

阿里云网站实名认证好看的友情链接代码

阿里云网站实名认证,好看的友情链接代码,android 做分享的网站,wordpress 结合qq二叉搜索树的最近公共祖先(Java) 重要结论:第一次遇到cur节点是数值在[q, p]区间中,那么cur就是q和p的最近公共祖先(闭区间是因为公共祖先可以是本身) (如果知道这个结论:本题就类似于给定二叉搜索树(BST&…

二叉搜索树的最近公共祖先(Java)

重要结论:第一次遇到cur节点是数值在[q, p]区间中,那么cur就是q和p的最近公共祖先(闭区间是因为公共祖先可以是本身)
(如果知道这个结论:本题就类似于给定二叉搜索树(BST)的根节点 root 和一个整数值 val—第700题)

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode(int x) { val = x; }* }*/class Solution {public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {if(root == null){return null;}if(root.val >= p.val && root.val <= q.val || (root.val >= q.val && root.val <= p.val)){return root;}else if(root.val > p.val && root.val > q.val){return lowestCommonAncestor(root.left, p, q);}else{return lowestCommonAncestor(root.right, p, q); //找到就是root,没找到就是null}}
}

删除二叉搜索树中的节点(Java)

大体框架:寻找是否有该节点。
细节:找到该节点后判断以下几种情况:

  • 左右孩子都为空:直接删除节点
  • 其无左子:其右子顶替其位置,删除了该节点;
  • 其无右子:其左子顶替其位置,删除了该节点;
  • 其左右子节点都有:其左子树转移到其右子树的最左节点的左子树上,然后右子树顶替其位置,由此删除了该节点。
/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public TreeNode deleteNode(TreeNode root, int key) { if(root == null){return null;}if(root.val == key){if(root.left == null && root.right == null){ //1:都为空直接删除return null;}else if(root.left == null || root.right == null){ // 2. 一侧为空,返回另一侧return root.left == null ? root.right : root.left;}else{ //3:左右两侧都有值TreeNode node = root.right;while(node.left != null){node = node.left; //不断寻找最左节点}node.left = root.left; // 把左节点放在右节点的最左节点的左边;return root.right;}}else if(root.val > key){root.left = deleteNode(root.left, key);}else{root.right = deleteNode(root.right, key);}return root;}
}

修剪二叉搜索树(Java)

  • 若 root.val 小于边界值 low,则 root 的左子树必然均小于边界值,我们递归处理 root.right 即可;
  • 若 root.val 大于边界值 high,则 root 的右子树必然均大于边界值,我们递归处理 root.left 即可;
  • 若 root.val 符合要求,则 root 可被保留,递归处理其左右节点并重新赋值即可。
/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public TreeNode trimBST(TreeNode root, int low, int high) {if(root == null){return null;}if(root.val < low){return  trimBST(root.right, low, high);}else if(root.val > high){return trimBST(root.left, low, high);}else{root.left = trimBST(root.left, low, high);root.right = trimBST(root.right, low, high);return root;}}
}

写博客的目的是每日督促并记录刷题,也欢迎大家批评指正~(day22)

http://www.dtcms.com/wzjs/187172.html

相关文章:

  • 上海传媒公司有哪些qq群排名优化软件购买
  • 做网站 数据库郑州seo优化服务
  • 怎么做免费个人网站万网的app叫什么
  • 征集二级网站建设意见 通知成都seo招聘信息
  • 大连网站优化步骤成都网站设计公司
  • 佛山网站建设网站制作公司哪家好seo课程简介
  • 推广网站挣钱裤子seo标题优化关键词
  • 江夏网站建设武汉百度开户电话
  • dreamweaver怎么做网页兰州seo优化公司
  • 上海建设工程协会网站seo优化6个实用技巧
  • 电影网站源码程序网站友链交换平台
  • 智能网站设计哪家好一份完整的电商运营方案
  • 赣州人才网下载伟哥seo博客
  • 耐思尼克网站推广手段
  • 网站搭建设计范文免费推广公司
  • 企业网上核名百度seo营销推广多少钱
  • 网站规划建设与管理维护的论文品牌策划方案怎么写
  • 网站做公司简介怎么做软文广告经典案例300
  • xp配置网站服务器线上推广外包公司
  • php建设网站后台营销软文100字
  • 响应式网站定制开发google商店
  • 设计排版优秀网站 今日头条
  • 自建网站优缺点网络推广平台软件app
  • 手机做网站知乎百度电脑网页版
  • 网站建设制作 南京公司seo五大经验分享
  • 全景网站制作教程优化网站价格
  • 提供网站建设备案报价新浪网今日乌鲁木齐新闻
  • 免费做情网站seo新人怎么发外链
  • 服装网站策划设计谷歌推广怎么样
  • 企业建设网站的规定网站推广排名