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

老虎淘客系统可以做网站吗中国免费域名申请网站

老虎淘客系统可以做网站吗,中国免费域名申请网站,网站如何让百度收录,如何把自己写的html变成网站236.二叉树的公共祖先 思路 看到题想的是找到两个点的各自路径利用stack保存,根据路径长度大小将两个stack的值对齐到同一层,之后同时出栈节点,若相同则找到祖先节点。但是效率不高 看了大佬代码,递归思想很难理解。 根据大佬…

236.二叉树的公共祖先

思路

看到题想的是找到两个点的各自路径利用stack保存,根据路径长度大小将两个stack的值对齐到同一层,之后同时出栈节点,若相同则找到祖先节点。但是效率不高

看了大佬代码,递归思想很难理解。

根据大佬代码思想写了一个便于理解的版本,分为四种情况,递归求解。

代码

简单方法

    Stack<TreeNode> stack=new Stack<>();public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {int deep_p=findDeep(root,p,1);Stack<TreeNode> stack_p=new Stack<>();stack_p.addAll(stack);stack.clear();int deep_q=findDeep(root,q,1);Stack<TreeNode> stack_q=new Stack<>();stack_q=stack;//将p作为长端if (deep_p<deep_q){int temp;Stack<TreeNode> stack1=new Stack<>();temp=deep_q;stack1.addAll(stack_q);stack_q.clear();deep_q=deep_p;stack_q.addAll(stack_p);stack_p.clear();deep_p=temp;stack_p.addAll(stack1);}while (deep_p>deep_q){stack_p.pop();deep_p--;}TreeNode node_q=stack_q.pop(),node_p=stack_p.pop();while (node_q!=node_p){node_q=stack_q.pop();node_p=stack_p.pop();}return node_q;}public int findDeep(TreeNode root,TreeNode node,int deep){stack.push(root);if (root==null) return 0;if (root==node) return deep;int left=findDeep(root.left,node,deep+1);if (left==0) stack.pop();int right=findDeep(root.right,node,deep+1);if (right==0) stack.pop();return   Math.max(left,right);}

大佬代码(比较难懂,O(n))

class Solution {public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {if(root == null || root == p || root == q) return root;TreeNode left = lowestCommonAncestor(root.left, p, q);TreeNode right = lowestCommonAncestor(root.right, p, q);if(left == null) return right;if(right == null) return left;return root;}
}

思想简化代码(O(4*n),多了4次find)

public class Solution {public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {if (root==null) return null;if (p==root || q==root) return root;//第一种情况,p,q其中一个为祖先节点if (find(root.left,p) && find(root.left,q)){ //第二种情况,p,q在当前节点左侧return lowestCommonAncestor(root.left,p,q);}if (find(root.right,p) && find(root.right,q)){//第三种情况,p,q在当前节点右侧return lowestCommonAncestor(root.right,p,q);}//第四种情况,p,q在两边return root;}public boolean find(TreeNode root,TreeNode p){if (root==null) return false;if (root==p) return true;return find(root.left,p) || find(root.right,p);}}
http://www.yayakq.cn/news/523306/

相关文章:

  • 新市区做网站上海百度推广平台
  • 做软件需要网站建设部门户网站
  • 网站设计的资质叫什么wordpress 头部 空行
  • 国企网站建设需要注意什么智能建造技术就业前景
  • 网站飘窗怎么做wordpress 360急速模式打不开
  • 电子东莞网站建设百度竞价广告推广
  • 那个网站专门做二手衣服的定制网站开发app费用
  • 和恶魔做交易的网站北京网站优化外包
  • 褚橙的网站建设做网站之前的前期
  • 中国建设银行安徽省分行招聘网站wordpress空间转移
  • 用html制作网站代码做期货在哪个网站查资料
  • 外贸响应式网站建设wordpress二级域名
  • 网站建设详情报价高质量外链网站
  • 漂亮的网站建设中静态页木樨园网站建设公司
  • 建设环境竣工验收网站wordpress is archive
  • 关键词挖掘啊爱站网网站图片切换怎么做的
  • 戒赌网站怎么做福州网站怎么做的
  • 昆明网站建设案例网络营销课程个人总结
  • 空白的网站怎么建设开发网站企业
  • 长沙网站建设260e营销型网站建设怎么做
  • 厦门网盛网站开发电子商务网站建设移动电商开发
  • 南宁保洁网站建设呼和浩特建站
  • 上海到北京高铁票价多少被逆冬seo课程欺骗了
  • 玉树州网站建设公司wordpress找回密码页面
  • 个人网站建设的小清新图片深圳十大高科技企业
  • 做网站连接数据库怎么显示图片wordpress免登录发文章
  • 济南做网站企业学设计的网站都有哪些
  • 昆明网站推广公司wordpress主页登录注册
  • 运城推广型网站建设公司备案号查询平台官网
  • 建设一个购物网站流程江苏国龙翔建设有限公司网站