一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - Java創(chuàng)建樹形結(jié)構(gòu)算法實例代碼

Java創(chuàng)建樹形結(jié)構(gòu)算法實例代碼

2020-07-30 15:23路偉 Java教程

本篇文章主要介紹了Java創(chuàng)建樹形結(jié)構(gòu)算法實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下。

JavaWeb的相關(guān)開發(fā)中經(jīng)常會涉及到多級菜單的展示,為了方便菜單的管理需要使用數(shù)據(jù)庫進行支持,本例采用相關(guān)算法講數(shù)據(jù)庫中的條形記錄進行相關(guān)組裝和排序講菜單組裝成樹形結(jié)構(gòu)

首先是需要的JavaBean

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
import java.io.Serializable;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.Date;
import java.util.Iterator;
import java.util.List;
 
/**
 * <Description> 菜單擴展<br>
 */
public class MenuExt implements Serializable {
 
  /**
   * 菜單ID
   */
  private Long id;
 
  /**
   * 菜單名稱
   */
  private String name;
 
  /**
   * 菜單地址
   */
  private String url;
 
  /**
   * 菜單圖標
   */
  private String icon;
 
  /**
   * 父菜單ID
   */
  private Long parentId;
 
  /**
   * 子菜單
   */
  private List<MenuExt> children = new ArrayList<MenuExt>();
 
  /**
   * 菜單順序
   */
  private Integer ordby;
 
  /**
   * 菜單狀態(tài)
   */
  private String state;
 
  //省略Getter和Setter
 
 
  /**
   *
   * <Description> 孩子節(jié)點排序<br>
   *
   */
  public void sortChildren() {
    Collections.sort(children, new Comparator<MenuExt>() {
      @Override
      public int compare(MenuExt menu1, MenuExt menu2) {
        int result = 0;
 
        Integer ordby1 = menu1.getOrdby();
        Integer ordby2 = menu2.getOrdby();
 
        Long id1 = menu1.getId();
        Long id2 = menu2.getId();
        if (null != ordby1 && null != ordby2) {
          result = (ordby1 < ordby2 ? -1 : (ordby1 == ordby2 ? 0 : 1));
        } else {
          result = (id1 < id2 ? -1 : (id1 == id2 ? 0 : 1));
        }
        return result;
      }
 
    });
    // 對每個節(jié)點的下一層節(jié)點進行排序
    for (Iterator<MenuExt> it = children.iterator(); it.hasNext();) {
      it.next().sortChildren();
    }
  }
 
  public List<MenuExt> getChildren() {
    return children;
  }
 
  public void setChildren(List<MenuExt> children) {
    this.children = children;
  }
}

Java算法

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
public static List<MenuExt> createTreeMenus(List<MenuExt> menus) {
    List<MenuExt> treeMenus = null;
    if (null != menus && !menus.isEmpty()) {
      // 創(chuàng)建根節(jié)點
      MenuExt root = new MenuExt();
      root.setName("菜單根目錄");
 
      // 組裝Map數(shù)據(jù)
      Map<Long, MenuExt> dataMap = new HashMap<Long, MenuExt>();
      for (MenuExt menu : menus) {
        dataMap.put(menu.getId(), menu);
      }
 
      // 組裝樹形結(jié)構(gòu)
      Set<Entry<Long, MenuExt>> entrySet = dataMap.entrySet();
      for (Entry<Long, MenuExt> entry : entrySet) {
        MenuExt menu = entry.getValue();
        if (null == menu.getParentId() || 0 == menu.getParentId()) {
          root.getChildren().add(menu);
        } else {
          dataMap.get(menu.getParentId()).getChildren().add(menu);
        }
      }
 
      // 對樹形結(jié)構(gòu)進行二叉樹排序
      root.sortChildren();
      treeMenus = root.getChildren();
    }
    return treeMenus;
  }

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:http://www.cnblogs.com/banning/p/6218633.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲午夜精品久久久久 | 袖珍人与大黑人性视频 | 俺去俺也在线www色官网 | 亚洲国产在线播放 | youjizzxxx69日本 | 毛片免费网站 | 哇嘎在线精品视频在线观看 | 午夜福利理论片高清在线 | 天堂在线观看中文字幕 | 午夜精品网站 | 视频在线观看一区二区 | freexxxx性大陆另类 | 4399h漫画| 日本草草视频在线观看 | 男gay网站视频免费观看 | 久久久久国产一级毛片高清片 | 免费午夜剧场 | 黄瓜视频导航 | 亚洲+国产+图片 | 久99视频精品免费观看福利 | 羞羞影院午夜男女爽爽影院网站 | 色综合合久久天天综合绕视看 | 毛片影院 | 色综合久久夜色精品国产 | 成品人视频w免费观看w | 国产精品免费小视频 | 日韩成人在线网站 | 性欧美13处丶14处 | 男人的j放进女人的p全黄 | 国产精品久久久久久久久免费hd | 亚洲福利天堂网福利在线观看 | 亚洲久草视频 | 女医学护士一级毛片 | 亚洲国产精品自产在线播放 | 四虎影视永久在线观看 | 欧美一区二区三区精品国产 | chaopeng在线观看 | 女bbbbxxx孕妇| 亚洲成年人免费网站 | 二次元美女内裤凹陷太深 | 四虎色影院 |