欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中遞歸構(gòu)建樹形結(jié)構(gòu)的算法解讀

 更新時間:2025年03月04日 08:48:50   作者:微笑聽雨。  
該文章介紹了如何使用Java遞歸算法構(gòu)建樹形結(jié)構(gòu),通過定義樹節(jié)點類,遍歷扁平數(shù)據(jù)列表,將節(jié)點加入對應父節(jié)點的子節(jié)點列表中,實現(xiàn)從扁平數(shù)據(jù)到樹形結(jié)構(gòu)的轉(zhuǎn)換

Java遞歸構(gòu)建樹形結(jié)構(gòu)的算法

java遞歸獲取樹

當我們處理像部門樹、菜單樹等樹形結(jié)構(gòu)數(shù)據(jù)時,我們需要從后端獲取一組扁平的數(shù)據(jù)列表。

這些數(shù)據(jù)列表通常由一個父節(jié)點ID字段和一個當前節(jié)點ID字段組成,這樣我們可以通過這兩個字段建立節(jié)點之間的父子關(guān)系。然后,我們可以利用這些數(shù)據(jù),通過遞歸的方式構(gòu)建樹形結(jié)構(gòu)。

  • 在Java后端中,我們可以通過遞歸函數(shù)來實現(xiàn)這一過程。
  • 首先,我們需要定義一個樹節(jié)點類,該類包含節(jié)點的基本信息和一個子節(jié)點列表。
  • 然后,我們遍歷扁平數(shù)據(jù)列表,對于每一個節(jié)點,我們將其加入到對應父節(jié)點的子節(jié)點列表中。
  • 如果當前節(jié)點沒有子節(jié)點,我們可以直接將其加入到樹的根節(jié)點列表中。
  • 然后,我們遞歸處理當前節(jié)點的子節(jié)點,直到所有節(jié)點都被加入到樹中。

通過這種方式,我們可以將扁平的數(shù)據(jù)列表轉(zhuǎn)換成樹形結(jié)構(gòu),使得數(shù)據(jù)更加清晰和有序。

這樣,前端可以利用這棵樹來構(gòu)建下拉菜單等形式的界面,為用戶提供更好的體驗。

代碼如下:

public static void main(String[] args) {
    // todo 業(yè)務數(shù)據(jù)
    List<TreeVo> treeVoList = new ArrayList<>();

	// 處理父節(jié)點為空的情況
    treeVoList
            .stream()
            .filter(obj -> StringUtils.isBlank(obj.getPid()))
            .forEach(obj -> obj.setPid("-1"));

	// 根據(jù)父節(jié)點分組
    Map<String, List<TreeVo>> treeCatch = treeVoList.stream()
            .collect(Collectors.groupingBy(TreeVo::getPid));

    // 遞歸查詢子節(jié)點,寫入當前數(shù)據(jù)
    treeVoList = findChildren(treeCatch, "-1");

    // 打印
    for (TreeVo treeVo : treeVoList) {
        System.out.println(JacksonUtil.bean2json(treeVo));
    }
}

private static List<TreeVo> findChildren(Map<String, List<TreeVo>> treeCatch, String parentId) {
    List<TreeVo> children = treeCatch.getOrDefault(parentId, new ArrayList<>());
    for (TreeVo treeVo : children) {
        List<TreeVo> subChildren = findChildren(treeCatch, treeVo.getId());
        treeVo.getChildren().addAll(subChildren);
    }
    return children;
}



/**
 * 獲取場地樹RVO
 */
public class TreeVo {

    /**
     * ID
     */
    private String id;

    /**
     * 名稱
     */
    private String name;
    
    /**
     * 父ID
     */
    private String pid;

    /**
     * 子級
     */
    private transient List<TreeVo> children;
	
	// 此處省略get\set
}

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringBoot整合MinIO實現(xiàn)文件存儲系統(tǒng)的代碼示例

    SpringBoot整合MinIO實現(xiàn)文件存儲系統(tǒng)的代碼示例

    在現(xiàn)代的應用程序中,文件存儲和管理是一個常見的需求,MinIO是一個開源的對象存儲系統(tǒng),與Spring?Boot框架結(jié)合使用,可以快速構(gòu)建高性能的文件存儲系統(tǒng),本文將介紹如何使用Spring?Boot和MinIO來實現(xiàn)文件存儲系統(tǒng)
    2023-06-06
  • SpringMVC多個文件上傳及上傳后立即顯示圖片功能

    SpringMVC多個文件上傳及上傳后立即顯示圖片功能

    這篇文章主要介紹了SpringMVC多個文件上傳及上傳后立即顯示圖片功能,非常不錯,具有參考借鑒價值功能,需要的朋友可以參考下
    2017-10-10
  • 淺談Java設(shè)計模式系列-裝飾器模式

    淺談Java設(shè)計模式系列-裝飾器模式

    這篇文章主要介紹了Java設(shè)計模式系列-裝飾器模式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03
  • SpringBoot?將配置文件掛到?jar?包外面的操作方法

    SpringBoot?將配置文件掛到?jar?包外面的操作方法

    在 SpringBoot 中,可以將配置文件放在 jar 包外面,這樣可以方便地修改配置而不需要重新打包和部署,這篇文章主要介紹了SpringBoot?如何將配置文件掛到?jar?包外面,需要的朋友可以參考下
    2023-03-03
  • Springboot整合PageOffice 實現(xiàn)word在線編輯保存功能

    Springboot整合PageOffice 實現(xiàn)word在線編輯保存功能

    這篇文章主要介紹了Springboot整合PageOffice 實現(xiàn)word在線編輯保存,本文以Samples5 為示例文件結(jié)合示例代碼給大家詳細介紹,需要的朋友可以參考下
    2021-08-08
  • Java開發(fā)必會的Linux命令

    Java開發(fā)必會的Linux命令

    這篇文章主要介紹了Java開發(fā)必會的Linux命令,幫助大家更好地進行java開發(fā),感興趣的小伙伴們可以參考一下
    2015-12-12
  • Java將日期類型Date時間戳轉(zhuǎn)換為MongoDB的時間類型數(shù)據(jù)

    Java將日期類型Date時間戳轉(zhuǎn)換為MongoDB的時間類型數(shù)據(jù)

    今天小編就為大家分享一篇關(guān)于Java將日期類型Date時間戳轉(zhuǎn)換為MongoDB的時間類型數(shù)據(jù),小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • Java服務端服務監(jiān)控:Prometheus與Spring Boot Actuator的集成方式

    Java服務端服務監(jiān)控:Prometheus與Spring Boot Actuator的集成方式

    本文介紹了如何將Prometheus與SpringBootActuator集成,實現(xiàn)對Java服務端應用的監(jiān)控,通過集成,可以利用Prometheus的強大監(jiān)控能力,及時發(fā)現(xiàn)和解決性能問題
    2024-12-12
  • Java面向?qū)ο笾b類的用途與實際使用

    Java面向?qū)ο笾b類的用途與實際使用

    所謂包裝類,就是能夠直接將簡單類型的變量表示為一個類,在執(zhí)行變量類型的相互轉(zhuǎn)換時,我們會大量使用這些包裝類,本文我們來深入探索一下Java包裝類的相關(guān)內(nèi)容,需要的朋友可以參考下
    2022-03-03
  • 帶你粗略了解Java數(shù)組的使用

    帶你粗略了解Java數(shù)組的使用

    這篇文章主要給大家介紹了關(guān)于Java中數(shù)組的定義和使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-08-08

最新評論