【数据结构和算法】--N叉树返回根节点到目标节点的路径

目录

一、前言

项目中接触一个问题:在大量有父子关系的列表中,需要筛选出特定约束的数据【要求某个目标节点延续到根节点的数据】。这个问题抽象为数据结构,就是:N叉树返回根节点到目标节点的路径

二、Java代码实现

java 复制代码
  public void createTreeInfo(){
        //查询所有的  有树形结构的列表数据
        List<NodeTreeDo> originList = new ArrayList<>();
        //构建出每层level的父子关系
        Map<String, List<NodeTreeDo>> children = originList.stream().collect(Collectors.groupingBy(node -> node.getParentId()));
        originList.forEach(node -> node.setChildren(children.get(node.getId())));
        //过滤得到从根节点""出发的所有N叉树链路
     //   List<NodeTreeDo> collect = originList.stream().filter(k->"".equals(k.getParentId())).collect(Collectors.toList());
       List<NodeTreeDo> collect = originList.stream().filter(k->"".equals(k.getId())).collect(Collectors.toList()); //从根节点level=0层得到所有链路数据
    }

    public List<String> getPathFromRoot(NodeTreeDo root,String targetId){
//        NodeTreeDo root = new NodeTreeDo();
//        root.setParentId("");
//        root.setId("00001");
//        root.setChildren(new ArrayList<>()); //具体的tree结构,这里做模拟样例
        /**
         * root是完整的树形结构
         */
        LinkedList<String> path = new LinkedList<>(); //找到从根节点到指定接定节点的路径
        getPathFromRoot(root,targetId,path);
        return path;
    }

    private boolean getPathFromRoot(NodeTreeDo root,String targetId, LinkedList<String> path){
        if(null == root) return false;
        String classid = root.getId();
        path.add(classid);
        if(classid.equals(targetId)) return true;
        boolean flag = false;
        List<NodeTreeDo> children = root.getChildren();
        if (null != children && !children.isEmpty()) {
            for (int i = 0; i < children.size(); i++) {
                if (!flag) {
                    flag = getPathFromRoot(root.getChildren().get(i), targetId, path);
                }
            }
        }
        if (!flag) {
            path.remove(path.size() - 1);//孩子中都找不到,弹出栈顶元素
        }
        return flag;
    }
相关推荐
liujing102329297 分钟前
Day04_刷题niuke20250703
java·开发语言·算法
2401_8812444043 分钟前
Treap树
数据结构·算法
乌萨奇也要立志学C++44 分钟前
二叉树OJ题(单值树、相同树、找子树、构建和遍历)
数据结构·算法
网安INF1 小时前
深度学习中的逻辑回归:从原理到Python实现
人工智能·python·深度学习·算法·逻辑回归
wsxqaz1 小时前
浏览器原生控件上传PDF导致hash值不同
算法·pdf·哈希算法
NAGNIP1 小时前
Transformer注意力机制——MHA&MQA&GQA
人工智能·算法
摘星编程1 小时前
多模态AI Agent技术栈解析:视觉-语言-决策融合的算法原理与实践
人工智能·算法·多模态ai·视觉语言融合·ai决策算法
NAGNIP1 小时前
一文搞懂KV-Cache
人工智能·算法
CoovallyAIHub1 小时前
RTMPose:重新定义多人姿态估计的“实时”标准!
深度学习·算法·计算机视觉
爱喝茶的小茶2 小时前
周赛98补题
开发语言·c++·算法