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

wordpress acf 收费哈尔滨seo关键字优化

wordpress acf 收费,哈尔滨seo关键字优化,做网站用html还是python好,企业如何找网络公司做网站目录 二叉树的最近公共祖先 题目 思路一:如果给定的是一颗二叉搜索树, 思路二:假设是孩子双亲表示法 二叉搜索树 定义Node类 查找 删除 插入 二叉树的最近公共祖先 题目 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百…

目录

二叉树的最近公共祖先

题目 

思路一:如果给定的是一颗二叉搜索树,

思路二:假设是孩子双亲表示法

 二叉搜索树

定义Node类

查找

删除

插入


二叉树的最近公共祖先

题目 

给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。

百度百科中最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖先)。”

提示:

树中节点数目在范围 [2, 105] 内。
-109 <= Node.val <= 109
所有 Node.val 互不相同 。
p != q
p 和 q 均存在于给定的二叉树中

思路一:如果给定的是一颗二叉搜索树,

二叉搜索树:中序遍历的大小是有序的,根节点的左树都比根节点的小,根节点的右树都比根节点大。

 

class Solution {public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {//先根据二叉搜索树来写if(root==null) return null;if(root==p||root==q) return root;TreeNode leftT=lowestCommonAncestor(root.left,p,q);TreeNode rightT=lowestCommonAncestor(root.right,p,q);if(leftT!=null&&rightT!=null){return root;}else if(leftT!=null){return leftT;}else{return rightT;}}
}

思路二:假设是孩子双亲表示法

就相当于链表求交点,但是我们的表示中没有双亲结点,因此我们引入两个栈。

1.用两个栈 存储root->q,root->p的路径;

2.求栈的大小;

3.让栈中多的元素出差值个元素;

4.开始出栈,直到栈顶元素相同,就是公共祖先;

如何去找到从根节点到一个指定节点的路径? 

class Solution {//root根结点,node:指定的节点,stack:存放根节点到指定节点的路径public boolean getPath(TreeNode root,TreeNode node ,Stack<TreeNode> stack){if(root==null||node==null) return false;stack.push(root);if(node==root) return true;boolean flg=getPath(root.left,node,stack);if(flg==true) return true;//找到啦flg=getPath(root.right,node,stack);if(flg==true) return true;//找到啦stack.pop();return false;}public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {if(root==null) return null;Stack<TreeNode> stack1=new Stack<>();getPath(root,p,stack1);Stack<TreeNode> stack2=new Stack<>();getPath(root,q,stack2);int size1=stack1.size();int size2=stack2.size();if(size1>size2){int size=size1-size2;while(size!=0){stack1.pop();size--;}while(!stack1.isEmpty()&&!stack2.isEmpty()){//直接判断地址if(stack1.peek()==stack2.peek()){return stack1.pop();}else{stack1.pop();stack2.pop();}}}else{int size=size2-size1;while(size!=0){stack2.pop();size--;}while(!stack1.isEmpty()&&!stack2.isEmpty()){//直接判断地址if(stack1.peek()==stack2.peek()){return stack2.pop();}else{stack1.pop();stack2.pop();}}}return null;}
}

 二叉搜索树

是空树或者:
若它的左子树不为空,则左子树上所有节点的值都小于根节点的值
若它的右子树不为空,则右子树上所有节点的值都大于根节点的值
它的左右子树也分别为二叉搜索树

定义Node类

class Node{public int val;public Node left;public Node right;public Node(int val){this.val=val;}
}

查找

  public Node root=null;public Node search(int key){Node cur = root;if(cur.val<key){cur = cur.right;}else if(cur.val>key){cur = cur.left;}else{return cur;}return null;}

删除

设待删除结点为 cur, 待删除结点的双亲结点为 parent
1. cur.left == null
1. cur root,则 root = cur.right
2. cur 不是 rootcur parent.left,则 parent.left = cur.right
3. cur 不是 rootcur parent.right,则 parent.right = cur.right
2. cur.right == null
1. cur root,则 root = cur.left
2. cur 不是 rootcur parent.left,则 parent.left = cur.left
3. cur 不是 rootcur parent.right,则 parent.right = cur.left
3. cur.left != null && cur.right != null
1. 需要使用替换法进行删除,即在它的右子树中寻找中序下的第一个结点(关键码最小),用它的值填补到被
删除节点中,再来处理该结点的删除问题

   //要删除节点,你需要知道这个节点的父节点//当要删除的节点的左节点为空//一般删除节点都是删除叶子节点public void f(Node cur,Node parent){if(cur.left==null){//当删除的节点左边没有节点if(cur==root){root=cur.right;}else if(cur==parent.left){parent.left=cur.right;}else{parent.right=cur.right;}}else if(cur.right==null){if(cur==root){root=cur.left;}else if(cur==parent.left){parent.left=cur.left;}else{parent.right=cur.left;}}else{//左右节点都不是空//相当于在右树中找一个较小值换到那个位置//或者就是在左树中找较大值//Node targetParent=cur;Node target=cur.right;while(target.left!=null){targetParent=target;target=target.left;}cur.val=target.val;if(target==targetParent.left){targetParent.left=target.right;}else{targetParent.right=target.right;}}}public void remove(int key){Node cur=root;Node parent=null;while(cur!=null){if(cur.val==key){f(cur,parent);break;}else if(cur.val<key){parent=cur;cur=cur.right;}else{parent=cur;cur=cur.left;}}}

插入

   //二叉搜索树插入的数据一定是在叶子节点//1.cur,parent来找到val需要存储的位置//2.parent.val比较大小,确定格式在左边还是右边进行插入public  boolean insert(int val){if(root == null){root = new Node(val);return true;}Node cur = root;Node parent = null;//找到parent的位置while(cur!=null){if(cur.val<val){parent=cur;cur=cur.right;}else if(cur.val==val){//bureturn false;}else{parent=cur;cur=cur.left;}}//找到对应位置开始插入Node node=new Node(val);if(parent.val<val){parent.right=node;}else{parent.left=node;}return true;}

http://www.yayakq.cn/news/412485/

相关文章:

  • 乌海市建设局网站在一家传媒公司做网站编辑_如何?
  • 渭南市工程建设项目审批网上办事大厅网站排名优化价格
  • 建网站程序怎么办房产网站加盟
  • 公司做网站一般多少钱企业网站建设招标书
  • 旅游网站建设规划书宁波网站建设联系方法
  • w网站制作和推广培训网站排名
  • 西部数码成品网站网页设计规范的主要内容
  • 网站开发公司计划书网站盈利方式
  • 国外空间网站备案毕业设计代做网站唯一
  • 申请完域名如何建网站电商如何做
  • 双语网站建设报价坂田做网站建设好的网络公司
  • 有关网站开发的参考文献福田所有车型
  • 滁州市大滁城建设网站和嗲囡囡和做的网站
  • 怎么进网站源码的后台做旅游网站设计的感想
  • 网站排名数据网站的创建历程怎么写
  • 商务网站设计特色移动互联网开发课程设计报告
  • 以网络营销为导向的网站建设应注意什么问题小蓝网页浏览器
  • 提供手机网站开发建行官网个人登录
  • 怎样在微信中做网站开封网站建设优化
  • 做竞价的网站手游游戏源码资源网
  • 网站建设及营销方案2022手机能看的你们知道
  • 大连 响应式网站制作石家庄做网站多少钱
  • 做网站需要用到的语言宝安商城网站建设
  • 松江品划做网站企业网站教程
  • 体贴的聊城网站建设建设网站要多久
  • wordpress 手机商城seo网络推广知识
  • 免费建站平台哪个好wordpress to微博
  • 网页设计网站开发教程妇联网站建设背景
  • 营销型网站建设设计6专业分销电商平台
  • 天津网站定制装修素材的网站大全