写一个简易的树结构,增加节点和遍历算法

本文介绍了树(Tree)这种非线性数据结构,重点展示了一个简单的TreeNode类,用于表示树节点,以及如何使用depthFirstTraversal方法进行深度优先遍历。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

         树(Tree)是非线性结构的典型代表。在树型数据结构中,数据元素之间存在一对多的关系。在数据结构中,对树的定义是:树是由n(n>0)个有限结点组成一个具有层次关系的集合。当n=0时,称为空树。

package com.gientech.atp.util;

import java.util.ArrayList;
import java.util.List;

public class TreeNode {
    String value;
    List<TreeNode> children;

    public TreeNode(String value) {
        this.value = value;
        this.children = new ArrayList<>();
    }

    public void addChild(TreeNode child) {
        this.children.add(child);
    }
}
 class TreeTraversal {
    public static void depthFirstTraversal(TreeNode node) {
        if (node == null) {
            return;
        }
        System.out.println(node.value);
        for (TreeNode child : node.children) {
            depthFirstTraversal(child);
        }
    }

    public static void main(String[] args) {
        TreeNode root = new TreeNode("A");
        TreeNode nodeB = new TreeNode("B");
        TreeNode nodeC = new TreeNode("C");
        TreeNode nodeD = new TreeNode("D");
        TreeNode nodeE = new TreeNode("E");

        root.addChild(nodeB);
        root.addChild(nodeC);
        nodeB.addChild(nodeD);
        nodeB.addChild(nodeE);

        depthFirstTraversal(root);
    }
}

        一个简单的树结构类 TreeNode 和一个用于深度优先遍历的方法 depthFirstTraversal

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值