SOURCE

class Node {
        constructor(key) {
            this.key = key;
            this.left = null;
            this.right = null;
        }
    }


    class BinaryTree{
        constructor() {
            this.root = null;
        }


        insert(key) {     // 插入数据
            var newNode = new Node(key);
            if (this.root == null) {
                this.root = newNode;
            } else {
                var current = this.root;
                while( true) {
                    if (key < current.key) {
                        if (current.left) {
                            current = current.left;
                        } else {
                            current.left = newNode;
                            break;
                        }
                    } else if (key > current.key) {
                        if (current.right) {
                            current = current.right;
                        } else {
                            current.right = newNode;
                            break;
                        }
                    }
                }
            }
          let node=this.root;
          if(this.getBalanceFactor(node)==0){
            return node
          }else if(this.getBalanceFactor(node)<-1){//右比左重
            if(key<node.right.key){//RR
              node=this.radionRR(node)
            }else{//RL
              node=this.radionRL(node)
            }
          }else if(this.getBalanceFactor(node)>1){//左比右重
            if(key<node.left.key){//LL
              node=this.radionLL(node)
            }else{//LR
              node=this.radionLR(node)
            }
          }
          this.root=node
        }

       getNodeHeight(node){
         if(node==null){
           return -1
         }
         return     Math.max(this.getNodeHeight(node.left),this.getNodeHeight(node.right))+1
       }
          
          getBalanceFactor(node){
            return this.getNodeHeight(node.left)-this.getNodeHeight(node.right)
          }
          
          radionLL(node){
            let temp=node.left
            node.left=temp.right
            temp.right=node
            return temp
          }
        
          radionRR(node){
            let temp=node.right
            node.right=temp.left
            temp.left=node
            return temp
          }
          
          radionRL(node){
            node.right=this.radionLL(node.right)
            return this.radionRR(node)
          }
          
          radionLR(node){
            node.left=this.radionRR(node.left)
            return this.radionLL(node)
          }
          
        centerSort(node,arr = []) {        // 中序排列
            if (node) {
                this.centerSort(node.left, arr);
                arr.push(node.key);
                this.centerSort(node.right,arr);
            }
            return arr;
        }

        prevSort(node, arr= []) {           // 前序排列
            if (node) {
                arr.push(node.key);
                this.prevSort(node.left, arr);
                this.prevSort(node.right, arr);
            }
            return arr;
        }

        nextSort(node, arr = []) {               // 后续排列
            if (node) {
                this.nextSort(node.left, arr);
                this.nextSort(node.right, arr);
                arr.push(node.key);
            }
            return arr;
        }

        getMin(node) {                // 获取二叉树的最小值
            node = node || this.root;
            while (node.left != null) {
                node = node.left;
            }
            return node.key;
        }

        getMax(node) {                //获取二叉树最大值
            node = node || this.root;
            while (node.right != null) {
                node = node.right;
            }
            return node.key;
        }

        find(key) {               // 查找 给定的值
            var node = this.root;
            while ( node != null) {
                if (key < node.key) {
                    node = node.left;
                } else if (key > node.key) {
                    node = node.right;
                } else {
                    return node;
                }
            }
            return null;
        }

        remove(key) {         // 删除给定的值
            this.root = this.removeNode(this.root, key);
          //删除操作
          let node=this.root;
          if(this.getBalanceFactor(node)==0){
            return node
          }else if(this.getBalanceFactor(node)<-1){//右比左重
            if(key<node.right.key){//RR
              node=this.radionRR(node)
            }else{//RL
              node=this.radionRL(node)
            }
          }else if(this.getBalanceFactor(node)>1){//左比右重
            if(key<node.left.key){//LL
              node=this.radionLL(node)
            }else{//LR
              node=this.radionLR(node)
            }
          }
          this.root=node
        }

        removeNode(node, key) {      // 真正删除的函数
            if (node == null) {
                return  null;
            }
            if (key < node.key) {
                node.left = this.removeNode(node.left, key);
                return node;
            } else if (key > node.key) {
                node.right = this.removeNode(node.right, key);
                return node;
            } else {
                if (node.left == null && node.right == null) {
                    node = null;
                    return node;
                } else if (node.left == null) {
                    return node.right;
                } else if (node.right == null) {
                    return node.left;
                } else {
                    var minNode = this.getMin(node.right);
                    node.key = minNode.key;
                    node.count = minNode.count;
                    node.right = this.removeNode(node.right, minNode.key);
                    return node;
                }
            }
        }

    }
let tree=new BinaryTree();
tree.insert(50)
tree.insert(30)
tree.insert(70)
tree.insert(10)
tree.insert(40)
tree.insert(5)
tree.remove(5)
tree.remove(10)
console.log(tree.prevSort(tree.root))
console 命令行工具 X clear

                    
>
console