• js实现对树深度优先遍历与广度优先遍历


    深度优先与广度优先的定义

    首先我们先要知道什么是深度优先什么是广度优先。

    深度优先遍历是指从某个顶点出发,首先访问这个顶点,然后找出刚访问这个结点的第一个未被访问的邻结点,然后再以此邻结点为顶点,继续找它的下一个顶点进行访问。重复此步骤,直至所有结点都被访问完为止。

    广度优先遍历是从某个顶点出发,首先访问这个顶点,然后找出刚访问这个结点所有未被访问的邻结点,访问完后再访问这些结点中第一个邻结点的所有结点,重复此方法,直到所有结点都被访问完为止。

    代码实现

    以下代码针对树的遍历实现,可能根据实际情况有所不同。

    有疑问的话可以咨询我。

    //1.深度优先遍历的递归写法
    function deepTraversal(node){
        let nodes=[];
        if(node!=null){
            nodes.push[node];
            let childrens=node.children;
            for(let i=0;i<childrens.length;i++)
                deepTraversal(childrens[i]);
        }
        return nodes;
    }
    
    //2.深度优先遍历的非递归写法
    function deepTraversal(node){
        let nodes=[];
        if(node!=null){
            let stack=[];//同来存放将来要访问的节点
            stack.push(node);
            while(stack.length!=0){
                let item=stack.pop();//正在访问的节点
                nodes.push(item);
                let childrens=item.children;
                for(let i=childrens.length-1;i>=0;i--)//将现在访问点的节点的子节点存入stack,供将来访问
                    stack.push(childrens[i]);
            }
        }
        return nodes;
    }
    
    //3.广度优先遍历的递归写法
    function wideTraversal(node){
        let nodes=[],i=0;
        if(node!=null){
            nodes.push(node);
            wideTraversal(node.nextElementSibling);
            node=nodes[i++];
            wideTraversal(node.firstElementChild);
        }
        return nodes;
    }
    
    //4.广度优先遍历的非递归写法
    function wideTraversal(node){
        let nodes=[],i=0;
        while(node!=null){
            nodes.push(node);
            node=nodes[i++];
            let childrens=node.children;
            for(let i=0;i<childrens.length;i++){
                nodes.push(childrens[i]);
            }
        }
        return nodes;
    }
    深度优先遍历从某个顶点出发,首先访问这个顶点,然后找出刚访问这个结点的第一个未被访问的邻结点,然后再以此邻结点为顶点,继续找它的下一个新的顶点进行访问,重复此步骤,直到所有结点都被访问完为止。
    广度优先遍历从某个顶点出发,首先访问这个顶点,然后找出这个结点的所有未被访问的邻接点,访问完后再访问这些结点中第一个邻接点的所有结点,重复此方法,直到所有结点都被访问完为止。
  • 相关阅读:
    list页面-按照choice筛选丶传condition过滤筛选项丶筛选与显示同步
    组件添加模糊搜索功能
    B
    51nod 1137矩阵乘法【矩阵】
    NYOJ 2356: 哈希计划【模拟】
    【数学基础】【最小公倍数和最大公约数】
    51 nod 1012 最小公倍数LCM【数论】
    poj 1753【枚举+dfs(位向量法)】
    【算法竞赛入门经典】7.3子集生成【增量构造法】【位向量法】【二进制法】
    1057 N的阶乘 【数论】
  • 原文地址:https://www.cnblogs.com/wuguanglin/p/DPSandBPS.html
Copyright © 2020-2023  润新知