徹底二叉樹是效率很高的數據結構,徹底二叉樹是由滿二叉樹而引出來的。
對於深度爲K的,有n個結點的二叉樹,當且僅當其每個結點都與深度
爲K的滿二叉樹中編號從1至n的結點一一對應時稱之爲徹底二叉樹。
二叉查找樹(Binary Search Tree),(又:二叉搜索樹,二叉排序樹)
它或者是一棵空樹,或者是具備下列性質的二叉樹: 若它的左子樹不空,
則左子樹上全部結點的值均小於它的根結點的值; 若它的右子樹不空,
則右子樹上全部結點的值均大於它的根結點的值; 它的左、右子樹也分別爲二叉排序樹。
排序二叉樹的實現考慮加入null的狀況。
//建立二叉樹
function Node(data,left,right){
this.val = data;
this.left = left;
this.right = right;
}
Node.prototype.show = function(){
return this.val;
}
function BST(){
this.root = null;
}
//查找二叉樹
BST.prototype.insert = function(data){
if(data === null){
return false
}
var node = new Node(data,null,null);
if(this.root == null){
this.root = node;
}else{
var current = this.root;
var parent;
while(true){
parent = current;
if(data < current.val){
current = current.left;
if(current == null){
parent.left = node;
break;
}
}else{
current = current.right;
if(current == null){
parent.right = node;
break;
}
}
}
}
}
//迭代方式建立普通給定數組順序二叉樹
BST.prototype.create = function(charecters){
var len = charecters.length ; //數組的長度
var nodes = new Array(); //建立一個臨時數組,用於存放二叉樹節點
//循環建立二叉樹節點存放到數組中
for (var i = 0 ; i < len ; i++) {
if(charecters[i]){
var node = new Node(charecters[i],null,null);
nodes.push(node);
}else{
nodes.push(null)
}
}
var index = 0;//索引從0開始
this.root = nodes[0];
// [ 5 , 1 , 4 , null , null , 3 , 6 , 6 , null , 7]
//1. ^ 5 ^
//2. ^ 1 ^
//3. ^ 4 ^
//4. ^ 3 ^
//count計算有null佔位的狀況
var count = 0
//循環創建二叉樹子節點的引用
while(index < len) {
if(nodes[index]){
var leftIndex = 2*(index-count)+1, //當前節點左孩子索引
rightIndex = 2*(index-count)+2; //當前節點右孩子索引
//給當前節點添加左孩子
nodes[index].left = nodes[leftIndex];
//給當前節點添加右孩子
nodes[index].right = nodes[rightIndex];
}else{
count++;
}
index++;
}
}
//遞歸方式建立普通給定數組順序二叉樹
BST.prototype.createRecurrence = function(charecters){
this.root = new Node(charecters[0],null,null);
var innerfun = function(nodes,i){
var leftIndex = 2*i+1,
rightIndex = 2*i+2;
if(leftIndex < charecters.length){
var node = new Node(charecters[leftIndex],null,null);
nodes.left = node;
innerfun(node,leftIndex);
}
if(rightIndex < charecters.length){
var node = new Node(charecters[rightIndex],null,null);
nodes.right = node;
innerfun(node,rightIndex);
}
}
innerfun(this.root,0)
}
//中序遍歷
BST.prototype.inOrder = function(node){
if(node){
this.inOrder(node.left);
console.log(node.show() + " ");
this.inOrder(node.right);
}
}
//堆棧 後進先出 將當前結點的孩子所有遍歷結束,在遍歷同一級的節點 深度優先搜索
BST.prototype.deepTraversal = function(node){
var list = []
var stack = []
stack.push(node)
while(stack.length !== 0){
var item = stack.pop()
list.push(item.val)
if(item.right){
stack.push(item.right)
}
if(item.left){
stack.push(item.left)
}
}
return list
}
//隊列 先進先出 根 第一層子節點 第二層子節點 左到右依次遍歷 廣度優先搜索
BST.prototype.wideTraversal = function(node){
var list = []
var stack = []
stack.push(node)
while(stack.length !== 0){
var item = stack.shift()
list.push(item.val)
if(item.left){
stack.push(item.left)
}
if(item.right){
stack.push(item.right)
}
}
return list
}
複製代碼
調用方式1:迭代生成
var bst = new BST();
var nums = [5,1,4,null,null,3,6,6,null,7]
bst.create(nums);
console.log(bst)
複製代碼
調用方式2:遞歸生成
var bst = new BST();
var nums = [5,1,4,null,null,3,6,6,null,7]
bst.createRecurrence(nums);
console.log(bst)複製代碼
調用方式3:
var bst = new BST();
var nums = [5,1,4,null,null,3,6,6,null,7]
for(var i = 0;i < nums.length;i ++){
bst.insert(nums[i]);
}
console.log(bst)
複製代碼