• javascript


    都是些简单的东西,所以直接上代码了。

    /**
     * Created by huangjacky on 14-10-3.
     */
    function Node(element, left, right) {
        this.element = element;
        this.level = 0;
        this.left = left;
        this.right = right;
    }
    
    function BST() {
        this.root = null;
    }
    BST.prototype = {
        insert: function (element) {
            var n = new Node(element, null, null);
            if (this.root == null) {
                this.root = n;
                n.level = 0;
                return true;
            } else {
                var current = this.root;
                var parent = null;
                while (current != null) {
                    if (element < current.element) {
                        parent = current;
                        current = current.left;
                    } else if (element > current.element) {
                        parent = current;
                        current = current.right;
                    } else {
                        return false;
                    }
                }
                n.level = parent.level + 1;
                if (element < parent.element) {
                    parent.left = n;
    
                } else {
                    parent.right = n;
                }
                return true;
            }
        }, toString: function () {
            return this.inOrder(this.root, function (n) {
                return "	" + n.element + '(' + n.level + ")	";
            });
        }, inOrder: function (n, fn) {// 中序遍历
            if (!n) {
                return '';
            } else {
                return this.inOrder(n.left, fn) + fn(n) + this.inOrder(n.right, fn);
            }
        }, preOrder: function (n, fn) { // 先序遍历
            if (!n) {
                return '';
            } else {
                return fn(n) + this.preOrder(n.left, fn) + this.preOrder(n.right, fn);
            }
        }, postOrder: function (n, fn) {// 后序遍历
            if (!n) {
                return '';
            } else {
                return this.postOrder(n.left, fn) + this.postOrder(n.right, fn) + fn(n);
            }
        }
    };
    
    var a = new BST();
    a.insert(3);
    a.insert(1);
    a.insert(5);
    a.insert(2);
    a.insert(4);
    console.log("inorder: " + a.toString());
    
    var fn = function (n) {
        return "	" + n.element + '(' + n.level + ")	";
    };
    var s1 = a.preOrder(a.root, fn);
    var s2 = a.postOrder(a.root, fn);
    console.log("pre order:" + s1);
    console.log("post order:" + s2);
    
  • 相关阅读:
    swoole 的 go function 是什么
    MySQL grant之后要不要跟上 flush privileges
    操作数据库
    APP端异常情况
    评论列表优化联表问题
    tp5修改数据前过滤
    字典
    if语句
    【整理】android事件传递机制
    Linux常用操作
  • 原文地址:https://www.cnblogs.com/huangjacky/p/4005317.html
Copyright © 2020-2023  润新知