1.定义测试数据类 VirtualDataGenerator;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

public class VirtualDataGenerator {
  public static List getVirtualResult() {
    List dataList = new ArrayList();

    HashMap dataRecord1 = new HashMap();
    dataRecord1.put("id", "112000");
    dataRecord1.put("name", "廊坊银行解放道支行");
    dataRecord1.put("parentId", "110000");

    HashMap dataRecord2 = new HashMap();
    dataRecord2.put("id", "112200");
    dataRecord2.put("name", "廊坊银行三大街支行");
    dataRecord2.put("parentId", "112000");

    HashMap dataRecord3 = new HashMap();
    dataRecord3.put("id", "112100");
    dataRecord3.put("name", "廊坊银行广阳道支行");
    dataRecord3.put("parentId", "112000");

    HashMap dataRecord4 = new HashMap();
    dataRecord4.put("id", "113000");
    dataRecord4.put("name", "廊坊银行开发区支行");
    dataRecord4.put("parentId", "110000");

    HashMap dataRecord5 = new HashMap();
    dataRecord5.put("id", "100000");
    dataRecord5.put("name", "廊坊银行总行");
    dataRecord5.put("parentId", "");

    HashMap dataRecord6 = new HashMap();
    dataRecord6.put("id", "110000");
    dataRecord6.put("name", "廊坊分行");
    dataRecord6.put("parentId", "100000");

    HashMap dataRecord7 = new HashMap();
    dataRecord7.put("id", "111000");
    dataRecord7.put("name", "廊坊银行金光道支行");
    dataRecord7.put("parentId", "110000");

    dataList.add(dataRecord1);
    dataList.add(dataRecord2);
    dataList.add(dataRecord3);
    dataList.add(dataRecord4);
    dataList.add(dataRecord5);
    dataList.add(dataRecord6);
    dataList.add(dataRecord7);

    return dataList;
  }
}

2.定义节点类 Node;

public class Node {
  /**
  * 节点内容
  */
  public String name;

  /**
  * 父节点编号
  */
  public String parentId;

  /**
  * 孩子节点列表
  */
  private Children children = new Children();

  // 先序遍历,拼接JSON字符串
  public String toString() {
    String result = "{" + "id : '" + id + "'" + ", name : '" + name + "'";

    if (children != null && children.getSize() != 0) {
      result += ", children : " + children.toString();
    } else {
      result += ", leaf : true";
    }

    return result + "}";
  }

  // 兄弟节点横向排序
  public void sortChildren() {
    if (children != null && children.getSize() != 0) {
      children.sortChildren();
    }
  }

  // 添加孩子节点
  public void addChild(Node node) {
    this.children.addChild(node);
  }
}

3.定义孩子类 Children;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.Iterator;
import java.util.List;

public class Children {

  private List list = new ArrayList();

  public int getSize() {
    return list.size();
  }

  public void addChild(Node node) {
    list.add(node);
  }

  // 拼接孩子节点的JSON字符串
  public String toString() {
    String result = "[";
    for (Iterator it = list.iterator(); it.hasNext();) {
      result += ((Node) it.next()).toString();
      result += ",";
    }
    result = result.substring(0, result.length() - 1);
    result += "]";
    return result;
  }

  // 孩子节点排序
  public void sortChildren() {
    // 对本层节点进行排序
    // 可根据不同的排序属性,传入不同的比较器,这里传入ID比较器
    Collections.sort(list, new NodeIDComparator());
    // 对每个节点的下一层节点进行排序
    for (Iterator it = list.iterator(); it.hasNext();) {
      ((Node) it.next()).sortChildren();
    }
  }
}

/**
* 节点比较器
*/
class NodeIDComparator implements Comparator {
  // 按照节点编号比较
  public int compare(Object o1, Object o2) {
    int j1 = Integer.parseInt(((Node) o1).id);
    int j2 = Integer.parseInt(((Node) o2).id);
    return (j1 < j2 ? -1 : (j1 == j2 ? 0 : 1));
  }
}

4.最后添加测试类进行测试 Test;

import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;

public class Test {
  public static void main(String[] args) {
    // 读取层次数据结果集列表
    List dataList = VirtualDataGenerator.getVirtualResult();
    // 节点列表(散列表,用于临时存储节点对象)
    HashMap nodeList = new HashMap();
    // 根节点
    Node root = null;
    // 根据结果集构造节点列表(存入散列表)
    for (Iterator it = dataList.iterator(); it.hasNext();) {
      Map dataRecord = (Map) it.next();
      Node node = new Node();
      node.id = (String) dataRecord.get("id");
      node.name = (String) dataRecord.get("name");
      node.parentId = (String) dataRecord.get("parentId");
      nodeList.put(node.id, node);
    }
    // 构造无序的多叉树
    Set entrySet = nodeList.entrySet();
    for (Iterator it = entrySet.iterator(); it.hasNext();) {
      Node node = (Node) ((Map.Entry) it.next()).getValue();
      if (node.parentId == null || node.parentId.equals("")) {
        root = node;
      } else {
        ((Node) nodeList.get(node.parentId)).addChild(node);
      }
    }
    // 输出无序的树形菜单的JSON字符串
    System.out.println(root.toString());
    // 对多叉树进行横向排序
    root.sortChildren();
    // 输出有序的树形菜单的JSON字符串
    System.out.println(root.toString());
  }
}

java实现树状图的更多相关文章

  1. D3树状图给指定特性的边特别显示颜色

    D3作为前端图形显示的利器,功能之强,对底层技术细节要求相对比较多. 有一点,就是要理解其基本的数据和节点的匹配规则架构,即enter,update和exit原理,我前面的D3基础篇中有介绍过,不明白 ...

  2. D3树状图异步按需加载数据

    D3.js这个绘图工具,功能强大不必多说,完全一个Data Driven Document的绘图工具,用户可以按照自己的数据以及希望实现的图形,随心所欲的绘图. 图形绘制,D3默认采用的是异步加载,但 ...

  3. SqlServer-无限递归树状图结构设计和查询

    在现实生活中,公司的部门设计会涉及到很多子部门,然后子部门下面又存在子部门,形成类似判断的树状结构,比如说评论楼中楼的评论树状图,职位管理的树状图结构等等,实现类似的树状图数据结构是在开发中经常出现的 ...

  4. Android开源图表之树状图和饼状图的官方示例的整理

    最近由于工作需要,所以就在github上搜了下关于chart的三方框架 官方地址https://github.com/PhilJay/MPAndroidChart 由于工作需要我这里整理了一份Ecli ...

  5. [整理] ES5 词法约定文档树状图

    将ES5 词法说明整理为了树状图,方便查阅,请自行点开小图看大图:

  6. bzoj 4871: [Shoi2017]摧毁“树状图” [树形DP]

    4871: [Shoi2017]摧毁"树状图" 题意:一颗无向树,选两条边不重复的路径,删去选择的点和路径剩下一些cc,求最多cc数. update 5.1 : 刚刚发现bzoj上 ...

  7. java集合树状结构及源码

    java集合树状结构及源码 最近一直想看一下java集合的源码,毕竟平时用的比较多,但总是感觉是跟着习惯new出来一个对象,比如ArrayList,HashMap等等,所以就简单的看了一下,了解了一下 ...

  8. vue 树状图数据的循环 递归循环

    在main.js中注册一个子组件 在父组件中引用 树状图的数据格式 绑定一个数据传入子组件,子组件props接收数据 子组件中循环调用组件,就实现了递归循环

  9. ztree 文件夹类型的 树状图

    未套程序的源代码: 链接:http://pan.baidu.com/s/1nuHbxhf 密码:4aw2 已套程序的源代码: css样式: /*发布邮件 选择领导弹窗*/ .xuandao{ disp ...

随机推荐

  1. DDMS调试信息

    1.可以使用System.out.println() 2.android.util包下的Log类 该类可以将信息以日志的形式输出到LogCat中: import android.util.Log; S ...

  2. U3D之Editor扩展学习

    Unity3D提供了强大的编辑器扩展机制,在项目开发中,如果可以将一些繁琐的工作放在编辑器扩展中进行,则会大大提高效率.本文对编辑器扩展进行了一些总结,希望对有兴趣编写编辑器扩展的开发人员有所帮助.当 ...

  3. 转:ANDROID音频系统散记之四:4.0音频系统HAL初探

    昨天(2011-11-15)发布了Android4.0的源码,今天download下来,开始挺进4.0时代.简单看了一下,发现音频系统方面与2.3的有较多地方不同,下面逐一描述. 一.代码模块位置 1 ...

  4. 转:桩模块 stub 和驱动模块 driver

    迷惑我很久的stub的概念,今天终于看到觉得靠谱的了,原文地址:http://xyzhaoangela.blog.hexun.com/14208786_d.html 桩模块stub:集成测试前要为被测 ...

  5. Ubuntu apt-get彻底卸载软件包

    https://blog.csdn.net/get_set/article/details/51276609 如果你关注搜索到这篇文章,那么我可以合理怀疑你被apt-get的几个卸载命令有点搞晕了. ...

  6. springboot---->集成mybatis开发(二)

    这里面我们介绍一下springboot集成mybatis完成一对多数据和一对一数据的功能.任何一个人离开你 都并非突然做的决定 人心是慢慢变冷 树叶是渐渐变黄 故事是缓缓写到结局 而爱是因为失望太多 ...

  7. 【linux系列】压缩和解压缩tar

    tar -c: 建立压缩档案-x:解压-t:查看内容-r:向压缩归档文件末尾追加文件-u:更新原压缩包中的文件 这五个是独立的命令,压缩解压都要用到其中一个,可以和别的命令连用但只能用其中一个.下面的 ...

  8. Android 框架

    1. https://github.com/wyouflf/xUtils xUtils简介 xUtils 包含了很多实用的android工具. xUtils 最初源于Afinal框架,进行了大量重构, ...

  9. C语言位操作--判断整数是否为2的幂

    unsigned int v; // 判断v是否为2的幂 bool f; // f为判断的结果 f = (v & (v - 1)) == 0; // 结果为0表示不是2 的幂 // 改变表示方 ...

  10. -bash: locate: command not found

    部分版本的linux系统使用locate快速查找某文件路径会报以下错误: -bash: locate: command not found 其原因是没有安装mlocate这个包 安装:yum  -y ...