java-用递归生成树形结构

1、准备实体对象
public class TreeNode{
	private int id;
	private int pid;
	private String name;
	private String content;
	private List<TreeNode> children;

	public TreeNode() {
	}

	public TreeNode(int id, int pid, String name, String content) {
		this.id = id;
		this.pid = pid;
		this.name = name;
		this.content = content;
	}

	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 String getContent() {
		return content;
	}

	public void setContent(String content) {
		this.content = content;
	}

	public List<TreeNode> getChildren(){
		return children;
	}

	public void setChildren(List<TreeNode> children){
		this.children = children;
	}

	@Override
	public String toString() {
		return "TreeNode{" +
				"id=" + id +
				", pid=" + pid +
				", name='" + name + '\'' +
				", content='" + content + '\'' +
				'}';
	}
}
2、准备测试数据
//生成测试数据方法
public static List<TreeNode> generateList(){
	List<TreeNode> list = new ArrayList<>();
	TreeNode treeModel1 = new TreeNode(1,0,"系统管理",getRandomStr());
	TreeNode treeModel2 = new TreeNode(11,1,"用户管理",getRandomStr());
	TreeNode treeModel3 = new TreeNode(111,11,"用户添加",getRandomStr());
	TreeNode treeModel4 = new TreeNode(2,0,"权限管理",getRandomStr());
	TreeNode treeModel5 = new TreeNode(21,2,"账号管理",getRandomStr());
	TreeNode treeModel6 = new TreeNode(221,2,"角色管理",getRandomStr());
	list.add(treeModel1);
	list.add(treeModel2);
	list.add(treeModel3);
	list.add(treeModel4);
	list.add(treeModel5);
	list.add(treeModel6);
	return list;
}

//随便写了一个由26个小写字母随机生成字符串方法
public static String getRandomStr(){
	StringBuilder ret= new StringBuilder();
	for (int i = 0; i < 6; i++) {
		int num=(int)(Math.random()*26+97);
		ret.append((char) num);
	}
	return ret.toString();
}
3、构造树形结构递归函数
/**
 * 生成树
 * @param list 待处理的数据集合
 * @param pid 最顶层的父级id
 */
public static List<TreeNode> createTree(List<TreeNode> list,int pid){
	//根据父id过滤出所有父节点
	List<TreeNode> tree = list.stream().filter(e-> pid == e.getPid()).collect(Collectors.toList());
	//遍历所有父节点,把属于该节点的所有子节点加到该节点的children属性下
	for (TreeNode node: tree) {
		int id = node.getId();
		//过滤出所有属于该节点的子节点
		List<TreeNode> cList = list.stream().filter(e-> id == e.getPid()).collect(Collectors.toList());
		//判断是否存在子节点,若子节点有数据则把该子节点的id作为pid继续递归往下层处理
		if(!SysUtil.isNull(cList)){
			createTree(list,id);
			node.setChildren(cList);
		}
	}
	return tree;
}
4、测试
public static void main(String[] args) throws Exception {

	List<TreeNode> list = generateList();
	list.forEach(System.out::println);
	List<TreeNode> tree = createTree(list,0);
	System.out.println(JSON.toJSONString(tree));


}
5、输出结果
TreeNode{id=1, pid=0, name='系统管理', content='vyzjpq'}
TreeNode{id=11, pid=1, name='用户管理', content='qwbiex'}
TreeNode{id=111, pid=11, name='用户添加', content='zuyuth'}
TreeNode{id=2, pid=0, name='权限管理', content='ctgevw'}
TreeNode{id=21, pid=2, name='账号管理', content='ulgvdx'}
TreeNode{id=221, pid=2, name='角色管理', content='fzxufe'}
[{"children":[{"children":[{"content":"zuyuth","id":111,"name":"用户添加","pid":11}],"content":"qwbiex","id":11,"name":"用户管理","pid":1}],"content":"vyzjpq","id":1,"name":"系统管理","pid":0},{"children":[{"content":"ulgvdx","id":21,"name":"账号管理","pid":2},{"content":"fzxufe","id":221,"name":"角色管理","pid":2}],"content":"ctgevw","id":2,"name":"权限管理","pid":0}]

  • 9
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
下面是一个简单的 Java 代码示例,用于生成树形结构: ```java public class Node { private String name; private List<Node> children; public Node(String name) { this.name = name; this.children = new ArrayList<>(); } public void addChild(Node child) { this.children.add(child); } public String getName() { return name; } public List<Node> getChildren() { return children; } } public class Tree { private Node root; public Tree(Node root) { this.root = root; } public void print() { print(root, 0); } private void print(Node node, int level) { for (int i = 0; i < level; i++) { System.out.print(" "); } System.out.println(node.getName()); for (Node child : node.getChildren()) { print(child, level + 1); } } } public class Main { public static void main(String[] args) { Node root = new Node("Root"); Node node1 = new Node("Node 1"); Node node2 = new Node("Node 2"); Node node3 = new Node("Node 3"); Node node4 = new Node("Node 4"); Node node5 = new Node("Node 5"); root.addChild(node1); root.addChild(node2); node2.addChild(node3); node2.addChild(node4); node3.addChild(node5); Tree tree = new Tree(root); tree.print(); } } ``` 这个示例中,我们定义了一个 `Node` 类来表示树中的节点,每个节点包含一个名称和一个子节点列表。我们还定义了一个 `Tree` 类来表示整个树,它包含一个根节点。我们使用递归方法打印整个树,每个节点在它的层数上印出两个空格,以形成缩进效果。在 `Main` 类中,我们创建了一个树并打印它。 输出结果如下: ``` Root Node 1 Node 2 Node 3 Node 5 Node 4 ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值