上下级(父子级)关系对象转为树形结构并打印树

对象

关系对象

public class Model {
	private String id;

	private String name;

	private Model parent;
	
	// 省略 get、set
}

树形对象

public class ModelNode{
	private String id;

	priate String name;

	private int count;

	private List<ModelNode> modelNodes;
	
	// 省略 get、set
}

构建树

/**
* 构建树
*
* @param models 所有对象
* @param 树
*/
public static List<ModelNode> buildTree(List<Model> models) {
    List<ModelNode> models = new ArrayList<>();
    models.forEach(model -> {
        // ROOT(s)
        if (null == model.getParent()) {
            ModelNode modelNode = toNode(model);
            models.add(modelNode);
            addChildren(models, model.getId(), modelNode);
        }
    });
    return models;
}

/**
 * 添加子节点
 *
 * @param models    所有对象
 * @param id           当前节点ID
 * @param modelNode 当前节点的树形结构对象
 */
private static void addChildren(List<Model> models, String id, ModelNode modelNode) {
    models.forEach(model -> {
        // 有父节点且父节点ID是当前传入节点
        if (null != model.getParent() && id.equals(model.getParent().getId())) {
            // 创建当前节点
            ModelNode children = toNode(model);
            // 添加当前节点为传入节点的子节点
            modelNode.getChildren().add(children);
            // 添加当前节点的子节点
            addChildren(models, model.getId(), children);
        }
    });
}

打印树

参考链接 https://stackoverflow.com/questions/4965335/how-to-print-binary-tree-diagram-in-java

代码

 /**
     * 打印树
     *
     * @param modelNodes 模型树
     */
    private static void printTree(List<ModelNode> modelNodes) {
        StringBuilder stringBuilder = new StringBuilder();
        modelNodes.forEach(modelNode -> buildTreeInfo(modelNode, stringBuilder, "", "", modelNode.getChildren()));
        log.debug("show model tree diagram \n {}", stringBuilder);
    }
private static void buildTreeInfo(ModelNode modelNode, StringBuilder buffer, String prefix, String childrenPrefix, List<ModelNode> children) {
    buffer.append(prefix);
    buffer.append(modelNode.getName());
    buffer.append('\n');
    if (null == children) {
        return;
    }
    for (Iterator<ModelNode> it = children.iterator(); it.hasNext(); ) {
        BizModelTreeDTO next = it.next();
        if (it.hasNext()) {
            buildTreeInfo(next, buffer, childrenPrefix + "├── ", childrenPrefix + "│   ", next.getChildren());
        } else {
            buildTreeInfo(next, buffer, childrenPrefix + "└── ", childrenPrefix + "    ", next.getChildren());
        }
    }
}

效果图

树形结构

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值