zoukankan      html  css  js  c++  java
  • 二叉树的创建,插入,查找,清空和比较

    二叉树的结构

    function TreeNode(){
        this.val = val;
        this.left = null;
        this.right = null;
    }

    二叉树的创建

    function createBTree(aVal,fPredicate,pos){
        var node = {};
        pos = pos || 0;
        if(fPredicate(aVal,pos) || !aVal[pos]){
            return null;
        }
        else{
            node.val = aVal[pos];
            node.left = createBTree(aVal,fPredicate,2*pos+1);
            node.right = createBTree(aVal,fPredicate,2*pos+2);
        }
        return node;
    }

    二叉树的插入节点

    function BTreeInsert(root,val,direction,node){
        if(root == null){
            return false;
        }
        if(root.val === val){
            switch(direction){
                case 'left':
                    if(root.left){
                        //throw new Error('left node already exists');
                        return false;
                    }
                    else{
                        root.left = node;
                    }
                    break;
                case 'right':
                    if(root.right){
                        //throw new Error('right node already exists');
                        return false;
                    }
                    else{
                        root.right = node;
                    }
                    break;
            }
        }
        else{
            BTreeInsert(root.left,node,val,direction);
            BTreeInsert(root.right,node,val,direction);
        }
        return true;
    }

    二叉树的查找节点

    function DLRFind(root, val) {
        if (root == null) {
            return null;
        }
        if (root.val === val) {
            return root;
        }
        return DLRFind(root.left, val) || DLRFind(root.right, val);
    }

    二叉树的比较

    function BTreeCompare(root1,root2){
        if(root1 == null && root2 == null){
            return true;
        }
        else if(root1 != null && root2 != null){
            return BTreeCompare(root1.left,root2.left)
                && BTreeCompare(root1.right,root2.right);
        }   
        else{
            return false;
        }
    }

    清空二叉树

    function BTreeClear(root){
        if(root == null){
            return true;
        }
        BTreeClear(root.left);
        BTreeClear(root.right);
        root = null;
        return true;
    }

    测试代码

    var root = createBTree([3, 2, 4, 6, 7, 8, 1, 0], function (aVal, pos) {
        return aVal[pos] == 0 || pos > 8
    }, 0);
    DLR(root);//output 3 2 6 7 4 8 1
    DLRFind(root,2);//output node 2
    DLRFind(root,11);//output null
    
    function createBTree(aVal, fPredicate, pos) {
        var node = {};
        pos = pos || 0;
        if (fPredicate(aVal, pos) || !aVal[pos]) {
            return null;
        } else {
            node.val = aVal[pos];
            node.left = createBTree(aVal, fPredicate, 2 * pos + 1);
            node.right = createBTree(aVal, fPredicate, 2 * pos + 2);
        }
        return node;
    }
    
    function DLR(root) {
        if (root == null) {
            return null;
        } 
        else {
            console.log('d ' + root.val);
            DLR(root.left);
            DLR(root.right);
        }
    }
    
    function DLRFind(root, val) {
        if (root == null) {
            return null;
        }
        if (root.val === val) {
            return root;
        }
        return DLRFind(root.left, val) || DLRFind(root.right, val);
    }
  • 相关阅读:
    心得
    构建之法--界面化的简单四则运算
    构建之法--简单四则运算
    构建之法--初识Git
    构建之法---第一次作业
    【软件工程实践】结对项目-四则运算 “软件”之升级版
    第三次作业:个人项目-小学四则运算 “软件”之初版
    分布式版本控制系统Git的安装与使用
    第一次作业-准备
    字符串、文件操作,英文词率统计预处理
  • 原文地址:https://www.cnblogs.com/mengff/p/6849835.html
Copyright © 2011-2022 走看看