java 构建树形结构_JAVA 快速构建树形结构

JDK 1.8+

Node 中pid 为 0 的是根节点

public class Node {

private int id;

private int pid;

private String name;

private List sub = new ArrayList<>();

public Node(int id, int pid) {

this.id = id;

this.pid = pid;

}

public Node(int id, int pid, String name) {

this(id, pid);

this.name = name;

}

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

public int getPid() {

return pid;

}

public void setPid(int pid) {

this.pid = pid;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public List getSub() {

return sub;

}

public void setSub(List sub) {

this.sub = sub;

}

}

public class TreeUtil {

public static List buildTree(List nodes) {

Map> sub = nodes.stream().filter(node -> node.getPid() != 0).collect(Collectors.groupingBy(node -> node.getPid()));

nodes.forEach(node -> node.setSub(sub.get(node.getId())));

return nodes.stream().filter(node -> node.getPid() == 0).collect(Collectors.toList());

}

}

public class Main {

public static void main(String[] args) {

Node dennis = new Node(1, 0, "dennis");

Node calm = new Node(2, 0, "calm");

Node daughter = new Node(3, 1, "daughter");

Node grandson = new Node(4, 3, "grandson");

Node son = new Node(5, 2, "son");

List nodes = Lists.newArrayList(dennis, calm, daughter, son, grandson);

List tree = TreeUtil.buildTree(nodes);

System.out.println(JSON.toJSONString(tree));

}

}

[

{

"id": 1,

"name": "dennis",

"pid": 0,

"sub": [

{

"id": 3,

"name": "daughter",

"pid": 1,

"sub": [

{

"id": 4,

"name": "grandson",

"pid": 3

}

]

}

]

},

{

"id": 2,

"name": "calm",

"pid": 0,

"sub": [

{

"id": 5,

"name": "son",

"pid": 2

}

]

}

]

标签:Node,JAVA,name,int,pid,public,树形,构建,id

来源: https://www.cnblogs.com/huangjinyong/p/12383315.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值