父子级节点构造树

JAVA 构造树形菜单

数据如图 P_ORG_NO 是父级节点编号 将此构造成一颗菜单树
在这里插入图片描述

   public List<OrgVO> buildOrgTree(){
        List<OrgVO> orgs = orgMapper.selectAll(dataSourceName);
        List<OrgVO> returnList = new ArrayList<>();
        List<String> tempList = orgs.stream().map(OrgVO::getOrgNo).collect(Collectors.toList());
        for (OrgVO org : orgs) {
            // 如果是顶级节点, 遍历该父节点的所有子节点
            if (!tempList.contains(org.getPOrgNo())) {
                recursionFn(orgs, org);
                returnList.add(org);
            }
        }
        if (returnList.isEmpty()) {
            returnList = orgs;
        }
        return returnList;
    }


    private void recursionFn(List<OrgVO> list, OrgVO t) {
        //得到子节点列表
        List<OrgVO> childList = getChildList(list, t);
        t.setChildrenList(childList);
        for (OrgVO tChild : childList) {
            if (hasChild(list, tChild)) {
                recursionFn(list, tChild);
            }
        }
    }

    /**
     * 获取子节点
     * @param list list
     * @param t t
     * @return 子节点列表
     */
    private List<OrgVO> getChildList(List<OrgVO> list, OrgVO t) {
        List<OrgVO> tlist = new ArrayList<>();
        for (OrgVO n : list) {
            if (n.getPOrgNo().equals(t.getOrgNo())) {
                tlist.add(n);
            }
        }
        return tlist;
    }


    /**
     * 判断是否有子节点
     *
     * @param list list
     * @param  t t
     * @return 判断是否有子节点
     */
    private boolean hasChild(List<OrgVO> list, OrgVO t) {
        return getChildList(list, t).size() > 0;
    }
@Data
@NoArgsConstructor
@AllArgsConstructor
@Builder
public class OrgVO {
    /**
    * 本实体记录的唯一标识
    */
    private String orgNo;

    /**
    * 详细的名称。
    */
    private String orgName;

    /**
    * 直接上级编号。
    */
    private String pOrgNo;


    /**
    * 在同级中的排列顺序的序号,用自然数标识,如,1、2、3
    */
    private Integer sortNo;


    private String orgShorthand;

    /**
     * 子级元素
     */
    private List<OrgVO> childrenList = new ArrayList<>();
@Data
@NoArgsConstructor
@AllArgsConstructor
public class TreeSelect implements Serializable {
    private static final long serialVersionUID = 1567893487236L;

    /**
     * 本实体记录的唯一标识
     */
    private String orgNo;

    /**
     * 详细的名称。
     */
    private String orgName;


    /**
     * 子节点
     */
    @JsonInclude(JsonInclude.Include.NON_EMPTY)
    private List<TreeSelect> childrenList;


    public TreeSelect(OrgVO org) {
        this.orgNo = org.getOrgNo();
        this.orgName = org.getOrgName();
        this.childrenList = org.getChildrenList().stream().map(TreeSelect::new).collect(Collectors.toList());
    }

}
@GetMapping("/tree")
    public CommonResult<OrgVO> orgTree() {

        List<OrgVO> orgTree = orgService.buildOrgTree();

        return CommonResult.ok("成功", orgTree.get(0));
    }
    @GetMapping("/nameTree")
    public CommonResult<TreeSelect> orgNameTree() {

        List<OrgVO> orgTree = orgService.buildOrgTree();

        List<TreeSelect> treeSelectList = orgTree.stream()
                .map(TreeSelect::new).collect(Collectors.toList());

        return CommonResult.ok("成功", treeSelectList.get(0));
    }
Java中,我们可以使用对象的父子关系构造形结构。首先,我们需要定义一个节点的类,该类包含节点的值以及子节点列表。例如,我们可以定义一个名为TreeNode的类: ```java class TreeNode { private int value; // 节点的值 private List<TreeNode> children; // 子节点列表 public TreeNode(int value) { this.value = value; this.children = new ArrayList<>(); } public int getValue() { return value; } public List<TreeNode> getChildren() { return children; } public void addChild(TreeNode child) { children.add(child); } } ``` 接下来,我们可以通过构建父子关系来构造。假设我们要构造如下形结构: ``` 1 / | \ 2 3 4 | 5 ``` 我们可以通过以下代码来构造这棵: ```java TreeNode root = new TreeNode(1); // 根节点 TreeNode node2 = new TreeNode(2); TreeNode node3 = new TreeNode(3); TreeNode node4 = new TreeNode(4); TreeNode node5 = new TreeNode(5); root.addChild(node2); // 1 -> 2 root.addChild(node3); // 1 -> 3 root.addChild(node4); // 1 -> 4 node3.addChild(node5); // 3 -> 5 ``` 现在,我们就成功地构造了一棵。通过使用父子关系,我们可以方便地遍历和操作节点。例如,可以使用递归的方式遍历整颗: ```java public void traverseTree(TreeNode node) { System.out.println(node.getValue()); List<TreeNode> children = node.getChildren(); for (TreeNode child : children) { traverseTree(child); } } traverseTree(root); ``` 这将输出中每个节点的值(1,2,3,4,5),并按照的结构进行打印。 通过构建父子关系,我们可以非常方便地设计和操作形结构。在实际应用中,结构常常用于表示层次关系或者分类结构,非常有用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值