zoukankan      html  css  js  c++  java
  • 构建一个时间复杂度为O(n)的目录树

    public class TreeTest{

    public static void test(Multimap<String, TestTreeBean> myMultimap,TestTreeBean bean){
    // 1.获取子节点
    List<TestTreeBean> childList = (List<TestTreeBean>) myMultimap.get(bean.getId());
    // 2.如果子节点已经没有数据跳出循环
    if(childList.size()==0){
    return;
    }else{
    // 3.遍历子节点
    for (TestTreeBean testTreeBean : childList) {
    // 递归当前节点是否有子节点
    test(myMultimap, testTreeBean);
    }
    // 4.构造子节点
    bean.setBean(childList);
    }

    }

    public static void main(String[] args) throws Exception {
    Multimap<String, TestTreeBean> myMultimap = ArrayListMultimap.create();
    List<TestTreeBean> list = new ArrayList<TestTreeBean>();
    // 1. 创造一份模拟数据
    list.add(new TestTreeBean("1", "0"));// 跟节点
    list.add(new TestTreeBean("2", "1"));
    list.add(new TestTreeBean("3", "1"));
    list.add(new TestTreeBean("4", "2"));
    list.add(new TestTreeBean("5", "2"));
    list.add(new TestTreeBean("6", "3"));
    // 2. 构造一个myMultimap父节点为key,myMultimap是键可以重复的数据结构,谷歌guava提供
    for (TestTreeBean testTreeBean : list) {
    myMultimap.put(testTreeBean.getPid(), testTreeBean);
    }
    // 3. 构造一个根节点,次节点可以为任意节点,为了获取此节点下的数据
    TestTreeBean bean = new TestTreeBean("1", "0", null);
    // 4. 递归构造目录树
    test(myMultimap, bean);
    System.out.println(JSON.toJSON(bean));
    }
    }

    public class TestTreeBean {
    private String id;

    private String pid;

    private List<TestTreeBean> bean;

    public TestTreeBean(String id, String pid) {
    super();
    this.id = id;
    this.pid = pid;
    }

    public TestTreeBean(String id, String pid, List<TestTreeBean> bean) {
    super();
    this.id = id;
    this.pid = pid;
    this.bean = bean;
    }

    public String getId() {
    return id;
    }

    public void setId(String id) {
    this.id = id;
    }

    public String getPid() {
    return pid;
    }

    public void setPid(String pid) {
    this.pid = pid;
    }

    public List<TestTreeBean> getBean() {
    return bean;
    }

    public void setBean(List<TestTreeBean> bean) {
    this.bean = bean;
    }

    @Override
    public String toString() {
    return "TestTreeBean [id=" + id + ", pid=" + pid + ", bean=" + bean + "]";
    }

  • 相关阅读:
    MFC 按钮
    读写文件
    遍历一个文件夹所有文件
    Java的运行机制
    selenium学习笔记——高级操作
    selenium学习笔记——定位元素
    selenium学习笔记——介绍&环境准备
    搭建安卓系统的测试环境
    Linux下Java环境的安装与配置
    Linux的目录结构介绍
  • 原文地址:https://www.cnblogs.com/btdxqz/p/6837535.html
Copyright © 2011-2022 走看看