递归遍历树结构

遍历树结构有三种顺序,根左右,左根右,左右根。


1、构造树结构

public class TreeNode<T> {
    public TreeNode<T> left;
    public TreeNode<T> right;
    public T data;

    public TreeNode(T data) {
        this.data = data;
    }
}

2、遍历

public class TreeSearch<T> {

    public StringBuffer path = new StringBuffer();

    public void per(TreeNode<T> root) {
        // 递归返回条件
        if (root == null) {
            return;
        }
        // 去掉开始的箭头
        if (!path.toString().equals("")) {
            path.append("->");
        }
        //  先输出根节点
        path.append(root.data);
        // 递归左节点
        per(root.left);
        // 递归右节点
        per(root.right);
    }

    public void mid(TreeNode<T> root) {
        if (root == null) {
            return;
        }
        mid(root.left);
        if (!path.toString().equals("")) {
            path.append("->");
        }
        path.append(root.data);
        mid(root.right);
    }

    public void suf(TreeNode<T> root) {
        if (root == null) {
            return;
        }
        suf(root.left);
        suf(root.right);
        if (!path.toString().equals("")) {
            path.append("->");
        }
        path.append(root.data);
    }

}

3、测试一下

public class TreeSearchTest {
    private static TreeNode<Integer> root = new TreeNode<>(1);
    @BeforeClass
    public static void beforeClass() {
        root.left = new TreeNode<>(2);
        root.right = new TreeNode<>(3);

        root.left.left = new TreeNode<>(4);
        root.left.right = new TreeNode<>(5);
        root.right.left = new TreeNode<>(6);
        root.right.right = new TreeNode<>(7);

        root.left.left.left = new TreeNode<>(8);
        root.left.left.right = new TreeNode<>(9);
        root.left.right.left = new TreeNode<>(10);
        root.left.right.right = new TreeNode<>(11);
        root.right.left.left = new TreeNode<>(12);
        root.right.left.right = new TreeNode<>(13);
        root.right.right.left = new TreeNode<>(14);
        root.right.right.right = new TreeNode<>(15);

    }

    @Test
    public void test() {
        TreeSearch<Integer> treeSearch = new TreeSearch<>();
        TreeSearch<Integer> treeSearch2 = new TreeSearch<>();
        TreeSearch<Integer> treeSearch3 = new TreeSearch<>();
        treeSearch.per(root);
        treeSearch2.mid(root);
        treeSearch3.suf(root);
        System.out.println(treeSearch.path);
        System.out.println(treeSearch2.path);
        System.out.println(treeSearch3.path);
    }

}



1->2->4->8->9->5->10->11->3->6->12->13->7->14->15
8->4->9->2->10->5->11->1->12->6->13->3->14->7->15
8->9->4->10->11->5->2->12->13->6->14->15->7->3->1


理解递归遍历树结构很简单,对遍历到的节点套用遍历规则即可。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
/** * 根据等级查询类目树 * * @param level * @return */ @Override public List queryCategoryTree(Integer level) { //查询当前级别下类目 List list = categoryDAO.list(level); //组装好的类目树,返回前端 List categoryTree = new ArrayList(); //所有类目 List allDTOList = new ArrayList(); if (CollectionUtils.isEmpty(list)) { return categoryTree; } for (CategoryDO categoryDO : list) { allDTOList.add(new CategoryTreeDTO().convertDOToDTO(categoryDO)); } //当前等级类目 categoryTree = allDTOList.stream().filter(dto -> level.equals(dto.getLevel())).collect(Collectors.toList()); for (CategoryTreeDTO categoryTreeDTO : categoryTree) { //组装类目为树结构 assembleTree(categoryTreeDTO, allDTOList,Constants.CATEGORY_MAX_LEVEL - level); } return categoryTree; } /** * 组装树 * * @param categoryTreeDTO * @param allList * @param remainRecursionCount 剩余递归次数 * @return */ public CategoryTreeDTO assembleTree(CategoryTreeDTO categoryTreeDTO, List allList, int remainRecursionCount) { remainRecursionCount--; //最大递归次数不超过Constants.CATEGORY_MAX_LEVEL-level次,防止坏数据死循环 if(remainRecursionCount < 0){ return categoryTreeDTO; } String categoryCode = categoryTreeDTO.getCategoryCode(); Integer level = categoryTreeDTO.getLevel(); //到达最后等级树返回 if (Constants.CATEGORY_MAX_LEVEL == level) { return categoryTreeDTO; } //子类目 List child = allList.stream().filter(a -> categoryCode.equals(a.getParentCode())).collect(Collectors.toList()); if (null == child) { return categoryTreeDTO; } categoryTreeDTO.setChildren(child); //组装子类目 for (CategoryTreeDTO dto : child) { assembleTree(dto, allList,remainRecursionCount); } return categoryTreeDTO; }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值