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

java遞歸實現(xiàn)樹形結(jié)構(gòu)數(shù)據(jù)完整案例

 更新時間:2023年04月21日 09:12:06   作者:無顏祖6246  
遞歸算法的代碼比較簡潔,可讀性較好;但是在實際的業(yè)務(wù)處理中會出現(xiàn)多次的重復(fù)調(diào)用,如果處理不好,很容易出現(xiàn)StackOverflowError報錯,這篇文章主要給大家介紹了關(guān)于java遞歸實現(xiàn)樹形結(jié)構(gòu)數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下

前言

本文提供兩種遞歸實現(xiàn)思路

樹形結(jié)構(gòu)數(shù)據(jù),大體的實現(xiàn)思路就是“父找子”,父節(jié)點去層層遞歸尋找子節(jié)點,最后組裝成數(shù)據(jù)集合。

提示:以下是本篇文章正文內(nèi)容,下面案例可供參考

一、樹形結(jié)構(gòu)是什么?

樹形結(jié)構(gòu),和我們平常所觸及到的無限級菜單,是同一個道理。

所謂樹形結(jié)構(gòu),我們可以將其理解為:樹根或者樹冠,都可以無限分叉下去。

現(xiàn)有一張表,需要對表中數(shù)據(jù)進行分級查詢(按照上下級關(guān)系進行排列),我們常用的數(shù)據(jù)庫有: oracle和mysql;

如果使用oracle的話,使用connect by,很容易就能做到;

但是,mysql沒有現(xiàn)成的遞歸函數(shù),需要我們自己使用存儲過程封裝,而且,就算封裝好了遞歸函數(shù),mysql在執(zhí)行的時候,查詢速度會很慢。如何解決這個問題呢?

既然數(shù)據(jù)庫不給力,我們只能交由程序來處理了,以減輕mysql數(shù)據(jù)庫的壓力。

二、實現(xiàn)方案

1、stream流遞歸實現(xiàn)

1.1 實體類

public class TreeBean {
 
    /**
     * id
     */
    private Integer id;
 
    /**
     * 名稱
     */
    private String name;
 
    /**
     * 父id ,根節(jié)點為0
     */
    public Integer parentId;
 
    /**
     * 子節(jié)點信息
     */
    public List<TreeBean> childList;
 
    public TreeBean() {
    }
 
    public TreeBean(Integer id, String name, Integer parentId, List<TreeBean> childList) {
        this.id = id;
        this.name = name;
        this.parentId = parentId;
        this.childList = childList;
    }
 
    public Integer getId() {
        return id;
    }
 
    public void setId(Integer id) {
        this.id = id;
    }
 
    public String getName() {
        return name;
    }
 
    public void setName(String name) {
        this.name = name;
    }
 
    public Integer getParentId() {
        return parentId;
    }
 
    public void setParentId(Integer parentId) {
        this.parentId = parentId;
    }
 
    public List<TreeBean> getChildList() {
        return childList;
    }
 
    public void setChildList(List<TreeBean> childList) {
        this.childList = childList;
    }
 
    /**
     * 初始化數(shù)據(jù)
     * @return
     */
    public List<TreeBean> initializationData() {
        List<TreeBean> list = new ArrayList<>();
        TreeBean t1 = new TreeBean(1, "廣東省", 0, new ArrayList<>());
        TreeBean t2 = new TreeBean(2, "湖南省", 0, new ArrayList<>());
        TreeBean t3 = new TreeBean(3, "廣州市", 1, new ArrayList<>());
        TreeBean t4 = new TreeBean(4, "長沙市", 2, new ArrayList<>());
        TreeBean t5 = new TreeBean(5, "白云區(qū)", 3, new ArrayList<>());
        TreeBean t6 = new TreeBean(6, "黃浦區(qū)", 3, new ArrayList<>());
        TreeBean t7 = new TreeBean(7, "白云街道", 5, new ArrayList<>());
        TreeBean t8 = new TreeBean(8, "深圳市", 1, new ArrayList<>());
        TreeBean t9 = new TreeBean(9, "寶安區(qū)", 8, new ArrayList<>());
        TreeBean t10 = new TreeBean(10, "福田區(qū)", 8, new ArrayList<>());
        TreeBean t11 = new TreeBean(11, "南山區(qū)", 8, new ArrayList<>());
        TreeBean t12 = new TreeBean(12, "南山街道", 11, new ArrayList<>());
        TreeBean t13 = new TreeBean(13, "芙蓉區(qū)", 4, new ArrayList<>());
        TreeBean t14 = new TreeBean(14, "岳麓區(qū)", 4, new ArrayList<>());
        TreeBean t15 = new TreeBean(15, "開福區(qū)", 4, new ArrayList<>());
        TreeBean t16 = new TreeBean(16, "岳陽市", 2, new ArrayList<>());
        TreeBean t17 = new TreeBean(17, "岳麓街道", 14, new ArrayList<>());
        list.add(t1);
        list.add(t2);
        list.add(t3);
        list.add(t4);
        list.add(t5);
        list.add(t6);
        list.add(t7);
        list.add(t8);
        list.add(t9);
        list.add(t10);
        list.add(t11);
        list.add(t12);
        list.add(t13);
        list.add(t14);
        list.add(t15);
        list.add(t16);
        list.add(t17);
        return list;
    }
}

1.2 實現(xiàn)類

/**
     * 方式一:Stream流遞歸實現(xiàn)遍歷樹形結(jié)構(gòu)
     */
    public static void treeTest1() {
        //獲取數(shù)據(jù)
        List<TreeBean> treeBeans = new TreeBean().initializationData();
        //獲取父節(jié)點
        List<TreeBean> collect = treeBeans.stream().filter(t -> t.getParentId() == 0).map(
                m -> {
                    m.setChildList(getChildren(m, treeBeans));
                    return m;
                }
        ).collect(Collectors.toList());
        System.out.println(JSON.toJSONString(collect));
    }

    /**
     * 遞歸查詢子節(jié)點
     * @param root  根節(jié)點
     * @param all   所有節(jié)點
     * @return 根節(jié)點信息
     */
    public static List<TreeBean> getChildren(TreeBean root, List<TreeBean> all) {
        List<TreeBean> children = all.stream().filter(t -> {
            return Objects.equals(t.getParentId(), root.getId());
        }).map(
                m -> {
                    m.setChildList(getChildren(m, all));
                    return m;
                }
        ).collect(Collectors.toList());
        return children;
    }

2、jdk1.7以下實現(xiàn)

2.1 節(jié)點類

便于提供前端取值

2.2 實現(xiàn)類

3、應(yīng)用場景

3.1 用于前端方便展示

如圖

3.2 用于查找并構(gòu)建子節(jié)點數(shù)據(jù)

以刪除菜單做例子,一般菜單未免會帶子菜單,所以,“父找子” 需求應(yīng)聲而來;

代碼如下:

總結(jié)

資料參考:

到此這篇關(guān)于java遞歸實現(xiàn)樹形結(jié)構(gòu)數(shù)據(jù)的文章就介紹到這了,更多相關(guān)java遞歸樹形結(jié)構(gòu)數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MybatisPlus分頁查詢與多條件查詢介紹及查詢過程中空值問題的解決

    MybatisPlus分頁查詢與多條件查詢介紹及查詢過程中空值問題的解決

    mybatisplus是個很好用的插件,相信小伙伴們都知道,下面這篇文章主要給大家介紹了關(guān)于mybatis-plus實現(xiàn)分頁查詢與多條件查詢介紹及查詢過程中空值問題的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • Java實現(xiàn)ATM機操作系統(tǒng)

    Java實現(xiàn)ATM機操作系統(tǒng)

    這篇文章主要為大家詳細介紹了Java實現(xiàn)ATM機操作系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Spring Boot 中使用cache緩存的方法

    Spring Boot 中使用cache緩存的方法

    Spring Cache是Spring針對Spring應(yīng)用,給出的一整套應(yīng)用緩存解決方案。下面小編給大家?guī)砹薙pring Boot 中使用cache緩存的方法,感興趣的朋友參考下吧
    2018-01-01
  • RocketMQ?Namesrv架構(gòu)工作原理詳解

    RocketMQ?Namesrv架構(gòu)工作原理詳解

    這篇文章主要為大家介紹了RocketMQ?Namesrv架構(gòu)工作原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 全網(wǎng)最全SpringBoot集成swagger的詳細教程

    全網(wǎng)最全SpringBoot集成swagger的詳細教程

    swagger是當(dāng)下比較流行的實時接口文文檔生成工具,swagger分為swagger2?和swagger3兩個常用版本,二者區(qū)別不是很大,主要對于依賴和注解進行了優(yōu)化,swagger2需要引入2個jar包,swagger3只需要一個,用起來沒有什么大的區(qū)別,本文給大家詳細介紹,感興趣的朋友一起看看吧
    2022-08-08
  • 詳解使用@RequestBody取POST方式的json字符串

    詳解使用@RequestBody取POST方式的json字符串

    這篇文章主要介紹了詳解使用@RequestBody取POST方式的json字符串,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • 總結(jié)Java調(diào)用Python程序方法

    總結(jié)Java調(diào)用Python程序方法

    這篇文章主要介紹了總結(jié)Java調(diào)用Python程序方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • SpringBoot2.6.x默認禁用循環(huán)依賴后的問題解決

    SpringBoot2.6.x默認禁用循環(huán)依賴后的問題解決

    由于SpringBoot從底層逐漸引導(dǎo)開發(fā)者書寫規(guī)范的代碼,同時也是個憂傷的消息,循環(huán)依賴的應(yīng)用場景實在是太廣泛了,所以SpringBoot 2.6.x不推薦使用循環(huán)依賴,本文給大家說下SpringBoot2.6.x默認禁用循環(huán)依賴后的應(yīng)對策略,感興趣的朋友一起看看吧
    2022-02-02
  • java 實現(xiàn)通過 post 方式提交json參數(shù)操作

    java 實現(xiàn)通過 post 方式提交json參數(shù)操作

    這篇文章主要介紹了java 實現(xiàn)通過 post 方式提交json參數(shù)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • Java8內(nèi)存模型PermGen Metaspace實例解析

    Java8內(nèi)存模型PermGen Metaspace實例解析

    這篇文章主要介紹了Java8內(nèi)存模型PermGen Metaspace實例解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03

最新評論