多樹表,遞歸查找所有分支及葉子的根

場(chǎng)景

  • 背景
    數(shù)據(jù)庫中有一張存儲(chǔ)樹結(jié)構(gòu)的表战坤,表中有子節(jié)點(diǎn)(childId)和父節(jié)點(diǎn)(parentId)對(duì)應(yīng)關(guān)系的字段曙强。表中存儲(chǔ)多棵樹的數(shù)據(jù),每棵樹的根節(jié)點(diǎn)(rootId)的特點(diǎn)是:childId與parentId相等途茫。數(shù)據(jù)如下圖:
Paste_Image.png
  • 需求
    表中每棵樹都可能有多級(jí)分支及多個(gè)葉子節(jié)點(diǎn)碟嘴,需要定位出表中所有節(jié)點(diǎn)歸屬的樹的根節(jié)點(diǎn)Id,放入map中(此處為java實(shí)現(xiàn))囊卜,map的結(jié)構(gòu)為map<childId,rootId>臀防。最終結(jié)果如下圖:
Paste_Image.png

思路

將表數(shù)據(jù)拼接取出眠菇,然后將數(shù)據(jù)轉(zhuǎn)換為兩個(gè)數(shù)組,一個(gè)是父節(jié)點(diǎn)數(shù)組袱衷、一個(gè)是子節(jié)點(diǎn)數(shù)組捎废,同時(shí),提取出表中的根節(jié)點(diǎn)數(shù)據(jù)致燥。
然后登疗,對(duì)子節(jié)點(diǎn)數(shù)組進(jìn)行遍歷,依據(jù)已經(jīng)確定的根節(jié)點(diǎn)嫌蚤,遞歸查找出每個(gè)子節(jié)點(diǎn)的根辐益,當(dāng)子節(jié)點(diǎn)數(shù)據(jù)遍歷完成,則所有數(shù)據(jù)定位完成脱吱。

實(shí)現(xiàn)代碼

從數(shù)據(jù)庫獲取表數(shù)據(jù)智政,拼接成“childId,parentId”字符串∠潋穑可以通過jdbc從查詢表续捂,獲取resultSet,遍歷resultSet進(jìn)行拼接宦搬,比較簡(jiǎn)單牙瓢,所以未編寫代碼。

/**
 * 多樹表间校,遞歸定位所有分支及葉子的根
 * @param child_parent_list
 * @author 張文健
 * @return
 */
public static Map<String,String> rootMap(List<String> child_parent_list){
    Map<String,String> child_parent_map = new HashMap<String,String>();
    String[] parentArr = new String[child_parent_list.size()];
    String[] childArr = new String[child_parent_list.size()];
    for(int i=0;i<child_parent_list.size();i++){
        String ic = child_parent_list.get(i).split(",")[0];
        String ip = child_parent_list.get(i).split(",")[1];
        parentArr[i] = ip;
        childArr[i] = ic;
        if(ic.equals(ip)){
            child_parent_map.put(ip, ip);
        }
    }
    goods: for(int i=0;i<childArr.length;i++){
            String finder = parentArr[i];
            machine: for(int j=0;j<childArr.length;j++){
                if(finder.equals(childArr[j])){
                    if(child_parent_map.containsValue(childArr[j])){
                        child_parent_map.put(childArr[i], childArr[j]);
                        continue goods;
                    }else{
                        finder = parentArr[j];
                        j=0;
                        continue machine;
                    }
                }
            }
        }
    return child_parent_map;
}

public static void main(String[] args) {
    List<String> child_parent_list = new ArrayList<String>();
    child_parent_list.add("000087,000086");
    child_parent_list.add("000088,000086");
    child_parent_list.add("000105,000088");
    child_parent_list.add("000106,000105");
    child_parent_list.add("000086,000086");
    child_parent_list.add("000091,000091");
    child_parent_list.add("000092,000091");
    child_parent_list.add("000093,000091");
    child_parent_list.add("000096,000096");
    child_parent_list.add("000097,000096");
    child_parent_list.add("000098,000096");
    child_parent_list.add("000099,000096");
    child_parent_list.add("000113,000111");
    child_parent_list.add("000112,000111");
    child_parent_list.add("000114,000111");
    child_parent_list.add("000111,000111");
    ServiceUtil.rootMap(child_parent_list);
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末矾克,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子憔足,更是在濱河造成了極大的恐慌胁附,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,482評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件滓彰,死亡現(xiàn)場(chǎng)離奇詭異控妻,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)找蜜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門饼暑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人洗做,你說我怎么就攤上這事弓叛。” “怎么了诚纸?”我有些...
    開封第一講書人閱讀 152,762評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵撰筷,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我畦徘,道長(zhǎng)毕籽,這世上最難降的妖魔是什么抬闯? 我笑而不...
    開封第一講書人閱讀 55,273評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮关筒,結(jié)果婚禮上溶握,老公的妹妹穿的比我還像新娘。我一直安慰自己蒸播,他們只是感情好睡榆,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,289評(píng)論 5 373
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著袍榆,像睡著了一般胀屿。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上包雀,一...
    開封第一講書人閱讀 49,046評(píng)論 1 285
  • 那天宿崭,我揣著相機(jī)與錄音,去河邊找鬼才写。 笑死葡兑,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的琅摩。 我是一名探鬼主播铁孵,決...
    沈念sama閱讀 38,351評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼锭硼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼房资!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起檀头,我...
    開封第一講書人閱讀 36,988評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤轰异,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后暑始,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體搭独,經(jīng)...
    沈念sama閱讀 43,476評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,948評(píng)論 2 324
  • 正文 我和宋清朗相戀三年廊镜,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了牙肝。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,064評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡嗤朴,死狀恐怖配椭,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情雹姊,我是刑警寧澤股缸,帶...
    沈念sama閱讀 33,712評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站吱雏,受9級(jí)特大地震影響敦姻,放射性物質(zhì)發(fā)生泄漏瘾境。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,261評(píng)論 3 307
  • 文/蒙蒙 一镰惦、第九天 我趴在偏房一處隱蔽的房頂上張望迷守。 院中可真熱鬧,春花似錦旺入、人聲如沸盒犹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽急膀。三九已至,卻和暖如春龄捡,著一層夾襖步出監(jiān)牢的瞬間卓嫂,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工聘殖, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留晨雳,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,511評(píng)論 2 354
  • 正文 我出身青樓奸腺,卻偏偏與公主長(zhǎng)得像餐禁,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子突照,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,802評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 樹的概述 樹是一種非常常用的數(shù)據(jù)結(jié)構(gòu)帮非,樹與前面介紹的線性表,棧讹蘑,隊(duì)列等線性結(jié)構(gòu)不同末盔,樹是一種非線性結(jié)構(gòu) 1.樹的定...
    Jack921閱讀 4,434評(píng)論 1 31
  • 1 序 2016年6月25日夜,帝都座慰,天下著大雨陨舱,拖著行李箱和同學(xué)在校門口照了最后一張合照,搬離寢室打車去了提前租...
    RichardJieChen閱讀 5,076評(píng)論 0 12
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法版仔,類相關(guān)的語法游盲,內(nèi)部類的語法,繼承相關(guān)的語法蛮粮,異常的語法益缎,線程的語...
    子非魚_t_閱讀 31,581評(píng)論 18 399
  • eclipse中的配置問題會(huì)對(duì)XML進(jìn)行校驗(yàn),比如DTD蝉揍,不符合它規(guī)矩就要帶著紅色叉號(hào)链峭,進(jìn)行如下操作即可: 1 右...
    peppermint_egg閱讀 5,828評(píng)論 0 2
  • 我叫端木森,沒有十歲之前的記憶又沾,也不知道自己的父母是誰弊仪。在孤兒院里長(zhǎng)大的我熙卡,身邊的朋友總是一個(gè)接著一個(gè)死去.......
    酷聽聽書閱讀 3,872評(píng)論 0 0