LeetCode Day3
Lowest Common Ancestor of a Binary Search Tree

import java.util.ArrayList;
import java.util.List;
/**
* LeetCode: Lowest Common Ancestor of a Binary Search Tree
* Given a binary search tree (BST), find the lowest common ancestor (LCA) of two given nodes in the BST
*
* @author LuoPeng
* @time 215.8.5
*
*/
public class LowestCommonAncestor {
/**
* If a node A is the common ancestor, and its left child and right child are not at the same time.
* A is the Lowest Common Ancestor
*
* @param root the root of the tree
* @param p
* @param q
* @return lowest common ancestor (LCA) of p and q
*/
public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
if ( root == null || p == root || q == root) {return root;}
TreeNode lca = null;
/*
* If one child is null, the lowest common ancestor must be the child of the other child of root
*/
if ( root.left == null) {
lca = lowestCommonAncestor(root.right, p, q);
} else if ( root.right == null) {
lca = lowestCommonAncestor(root.left, p, q);
} else {
boolean first = isCommonAncestor(root.left, p, q);
boolean second = isCommonAncestor(root.right, p, q);
if ( first) {
// if root.left is a common ancestor, the LCA must be root.left or a child of it.
lca = lowestCommonAncestor(root.left, p, q);
} else if (second) {
// if root.right is a common ancestor, the LCA must be root.right or a child of it.
lca = lowestCommonAncestor(root.right, p, q);
} else {
// For root is a common ancestor of p and q, the LCA must be root if the left child
// and right child are not the common ancestors.
lca = root;
}
}
return lca;
}
/**
* Whether root is the common ancestor of p and q
*
* @param root a node
* @param p a node
* @param q a node
* @return True if root is the common ancestor of p and q, otherwise false.
*/
private boolean isCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
if ( root == null) {return false;}
TempQueue queue = new TempQueue();
TreeNode temp = null;
boolean first = false;
boolean second = false;
// Breadth First Search
queue.push(root);
while ( !queue.empty()) {
temp = queue.peek();
queue.pop();
if ( temp ==p) {
first = true;
} else if ( temp == q) {
second = true;
}
// add the child
if ( temp.left != null) {
queue.push(temp.left);
}
if ( temp.right != null) {
queue.push(temp.right);
}
// break if p and q have bean found
if ( first && second) {
break;
}
}
return first && second;
}
}
/**
* Queue
*
*/
class TempQueue {
public void push(TreeNode x) {
values.add(x);
}
public void pop() {
values.remove(0);
}
public TreeNode peek() {
return values.get(0);
}
public int size() {
return values.size();
}
public boolean empty() {
return values.size()==0;
}
private List<TreeNode> values = new ArrayList<TreeNode>();
}
LeetCode Day3的更多相关文章
- 【LeetCode算法题库】Day3:Reverse Integer & String to Integer (atoi) & Palindrome Number
[Q7] 把数倒过来 Given a 32-bit signed integer, reverse digits of an integer. Example 1: Input: 123 Outpu ...
- leetcode每日刷题计划-简单篇day3
收到swe提前批面试hhh算是ep挂了的后续 努力刷题呀争取今年冲进去! Num 21 合并两个有序链表 Merge Two Sorted Lists 注意新开的链表用来输出结果的是ListNode ...
- 我为什么要写LeetCode的博客?
# 增强学习成果 有一个研究成果,在学习中传授他人知识和讨论是最高效的做法,而看书则是最低效的做法(具体研究成果没找到地址).我写LeetCode博客主要目的是增强学习成果.当然,我也想出名,然而不知 ...
- LeetCode All in One 题目讲解汇总(持续更新中...)
终于将LeetCode的免费题刷完了,真是漫长的第一遍啊,估计很多题都忘的差不多了,这次开个题目汇总贴,并附上每道题目的解题连接,方便之后查阅吧~ 477 Total Hamming Distance ...
- [LeetCode] Longest Substring with At Least K Repeating Characters 至少有K个重复字符的最长子字符串
Find the length of the longest substring T of a given string (consists of lowercase letters only) su ...
- Leetcode 笔记 113 - Path Sum II
题目链接:Path Sum II | LeetCode OJ Given a binary tree and a sum, find all root-to-leaf paths where each ...
- Leetcode 笔记 112 - Path Sum
题目链接:Path Sum | LeetCode OJ Given a binary tree and a sum, determine if the tree has a root-to-leaf ...
- Leetcode 笔记 110 - Balanced Binary Tree
题目链接:Balanced Binary Tree | LeetCode OJ Given a binary tree, determine if it is height-balanced. For ...
- Leetcode 笔记 100 - Same Tree
题目链接:Same Tree | LeetCode OJ Given two binary trees, write a function to check if they are equal or ...
随机推荐
- popToViewController用法
[self.navigationController popToViewController:[self.navigationController.viewControllers objectAtIn ...
- Struts2(四)——页面相关内容
上篇博客总结了数据流转各个方面的内容,这篇重点说一下框架对于界面上知识. 一,说到页面,记得在总体介绍中,说到Struts2比Struts1的一方面优势就是它支持更多的视图技术(Freemarker, ...
- 【SDUT 3038】迷之博弈
action=showproblem&problemid=3038">[SDUT 3038]迷之博弈 简直就是上次省赛的缩减版... 仅仅只是这个是链 省赛是环. ..1 2先 ...
- 用Unity做的一个小游戏,仿照一个样例写的,个人认为文章写的不错,哈哈
- R学习笔记
把学习过程记载下来,加深印象,到时要是忘了也容易查,有需要的同学也可以参考: 1.包的安装:两种方法:一种通过R的菜单,先设定cran镜像,然后安装程序包,会出来一个列表,选择相应程序包安装,安装完毕 ...
- EF MySQL 提示 Specified key was too long; max key length is 767 bytes错误
在用EF的CodeFirst操作MySql时,提示 Specified key was too long; max key length is 767 bytes错误,但数据库和表也建成功了.有高人知 ...
- 使用FindControl("id")查找控件 返回值都是Null的问题
做了一个通过字符串ID查找页面控件并且给页面控件赋值的功能,过程中遇到了this.FindControl("id")返回值都是Null的问题,记录一下解决办法. 问题的原因是我所要 ...
- ‘Microsoft.Jet.OLEDB.4.0’ provider is not registered
正如以下msdn论坛所述,Microsoft.Jet.OLEDB.4.0只有32bit,所以我们必须compile application to x86 platform. http://social ...
- C语言undefined behaviour未定义行为
C语言中的未定义行为(Undefined Behavior)是指C语言标准未做规定的行为.同时,标准也从没要求编译器判断未定义行为,所以这些行为有编译器自行处理,在不同的编译器可能会产生不同的结果,又 ...
- oracle中闪回错误的dml操作原理
原理: Oracle根据还原表空间信息,利用还原表空间中的数据,类似一致性读取方法,可以把表置于一个删除前的时间点(或SCN),从而将数据找回. 删除删除错误的dml操作的oracle的前提准备: 一 ...