Binary Tree和Binary Search Tree
Binary Tree
Definition: at most two children node.
Binary Tree Example:
10 ==root
/ \
13 15 cur
/ \ / \
21 72 12 2
/ \
null null
class TreeNode{
int value;
TreeNode * left;
TreeNode * right;
TreeNode * parent //point to this node's parent node.
}
面试常见题型:
基本知识点1: tree traverse
1. pre-order.
2.in-order.
3.post-order.
关键点:base case通常就是叶子节点下面的空节点。
Balanced binary tree:
对于树的任意一个节点,左子树和右子树的高度差不超过1。
Complete binary tree(完全二叉树)
底层是一个数组,数组内部的数字必须是连续的,不能有空余的内存空间。
Binary Search Tree(二叉查找树)
10
/ \
5 15
/ \ / \
2 7 12 20
注意:对于根节点10,必须整个左子树(左子树上的所有节点)都必须比10小,整个右子树(右子树上的所有节点)必须比10大。
同时binary search tree不允许有重复的node;
Binary tree 往往是最常见的和recursion结合最紧密的面试题目类型。
理由:
1.每层的node所具备的性质,传递的值和下一层的性质往往一致,比较容易定义recursive rule。
2.base case: null pointer under the leaf node.
3.Example1:int getHeight(Node root)
4.Example2:统计tree里面有多少个node。
常见面试题型:
How to get integer value(height) for a problem with size = n? But how?
GetHeight of a binary tree?
public int getHeight(TreeNode root){
if(root == null){
return 0;
}
int left = getHeight(root.left);
int right = getHeight(root.right);
return 1 + Math.max(left,right);
}
Time = O(n);
space = O(n) == O(height);
---------------------------------------------------------------------------------------------------------------------------
Q3:How to determine whether a binary tree is a balanced binary tree?
public boolean isBalanced(TreeNode tree){
if(root == null){
return true;
}
int left = getHeight(root.left);
int right = getHeight(root.right);
if(Math.abs(left - right) > 1){
return false;
}
return isBalanced(root.left) && isBalanced(root.right);
}
时间复杂度分析:
isBalanced(n/2 + n/2)
/ \
getHeight getHeight
(n/4 + n/4) (n/4 + n/4)
因为是一个平衡二叉树所以:层数logn So: Time : O(nlogn)
---------------------------------------------------------------------------------------------------------------------------
Q4:怎么判断一颗二叉树左右两边是不是对称的?
10
5a | 5b
1a 3a | 3b 1b
2a4a 6a8a | 8b6b 4b2b
public boolean isSymmetric(TreeNode noe,TreeNode two){
if(one == null && two == null){
return true;
}
if(one ==null || two == null){
return false;
}
if(one.value == two.value){
return false;
}
return isSymmetric(one.left,two.right) && isSymmetric(one.right,one.left);
}
Time = O(n);
space = O(n) -> O(height) if the tree is balaced -> O(logn)
---------------------------------------------------------------------------------------------------------------------------
Q5:
Binary Tree和Binary Search Tree的更多相关文章
- [数据结构]——二叉树(Binary Tree)、二叉搜索树(Binary Search Tree)及其衍生算法
二叉树(Binary Tree)是最简单的树形数据结构,然而却十分精妙.其衍生出各种算法,以致于占据了数据结构的半壁江山.STL中大名顶顶的关联容器--集合(set).映射(map)便是使用二叉树实现 ...
- Leetcode 笔记 99 - Recover Binary Search Tree
题目链接:Recover Binary Search Tree | LeetCode OJ Two elements of a binary search tree (BST) are swapped ...
- Leetcode 笔记 98 - Validate Binary Search Tree
题目链接:Validate Binary Search Tree | LeetCode OJ Given a binary tree, determine if it is a valid binar ...
- Leetcode: Convert sorted list to binary search tree (No. 109)
Sept. 22, 2015 学一道算法题, 经常回顾一下. 第二次重温, 决定增加一些图片, 帮助自己记忆. 在网上找他人的资料, 不如自己动手. 把从底向上树的算法搞通俗一些. 先做一个例子: 9 ...
- [LeetCode] Closest Binary Search Tree Value II 最近的二分搜索树的值之二
Given a non-empty binary search tree and a target value, find k values in the BST that are closest t ...
- [LeetCode] Closest Binary Search Tree Value 最近的二分搜索树的值
Given a non-empty binary search tree and a target value, find the value in the BST that is closest t ...
- [LeetCode] Verify Preorder Sequence in Binary Search Tree 验证二叉搜索树的先序序列
Given an array of numbers, verify whether it is the correct preorder traversal sequence of a binary ...
- [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 BS ...
- [LeetCode] Binary Search Tree Iterator 二叉搜索树迭代器
Implement an iterator over a binary search tree (BST). Your iterator will be initialized with the ro ...
- [LeetCode] Convert Sorted List to Binary Search Tree 将有序链表转为二叉搜索树
Given a singly linked list where elements are sorted in ascending order, convert it to a height bala ...
随机推荐
- SMBUS与I2C
SMBUS(系统管理总线)基于I2C总线,主要用于电池管理系统中.它工作在主/从模式:主器件提供时钟,在其发起一次传输时提供一个起始位,在其终止一次传输时提供一个停止位:从器件拥有一个唯一的7或10位 ...
- Python基础入门语法1
PY的交换值的方法 x.y = y.x PY既具有动态脚本的特性,又有面向对象的特性 PY的缺点: 编译型的语言(C++,C):通过编译器进行编译成机器码,越接近底层,开发效率低 解释型代码:PY和J ...
- Red Black Tree(红黑树)
(修改于 2018-05-06 15:53:22 还差删除维护操作.层序遍历没完成.维护操作没完成不想写层序遍历怎么办...) 今天下午完成了红黑树的插入的维护操作,但删除的维护操作还没有解决,删除的 ...
- ubuntu-18.04 修改用户名密码
1. 开放root登录 设置root密码 $ sudo passwd root 切换到root 用户 $ sudo -i 修改/etc/pam.d/gdm-autologin $ vim /etc/p ...
- Spring学习(三)
DI (Dependency Injection) 1.依赖注入,组件之间的依赖关系由容器在运行期间决定.Ioc容器注入应用程序某个对象,它所需要的外部资源(包括对象,资源,常量数据). birthd ...
- Excel使用小技巧
1.Excel随机设置单元格的内容为整数0或1: 在单元格中写公式: =ROUND(RAND(),0) 2.设置某个单元格的值为1或0,根据其他3个单元格的值为0或1来确定: 在该单元格中写公式: ...
- Navicat连接mysql时候出现1251错误代码
出现1251错误代码 是因为mysql8.0的密码加密方式与之前5.0的不同 如果是字母式的密码 比如root 可能会出现这种情况 1.先通过命令行进入mysql的root账户 Enter passw ...
- SpringBoot之日志记录-专题四
SpringBoot之日志记录-专题四 六.日志管理 6.1使用log4j记录日志 6.1.2新建log4j配置文件 文件名称log4j.properties #log4j.rootLogger=CO ...
- Java - 实现双向链表
熟悉一下Java... package ChianTable; import java.util.Scanner; /** * Created by Administrator on 2018/3/2 ...
- Python 基础之序列化模块pickle与json
一:pickle 序列化模块把不能够直接存储的数据,变得可存储就是序列化把存储好的数据,转化成原本的数据类型,加做反序列化 php: 序列化和反序列化(1)serialize(2)unserializ ...