



下載本文檔
版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第一文掌握J(rèn)avaScript樹(shù)結(jié)構(gòu)深度優(yōu)先算法在現(xiàn)實(shí)生活中,相信每個(gè)人對(duì)樹(shù)都很熟悉,不管是柳樹(shù)、楊樹(shù)還是桃樹(shù),可以說(shuō)樹(shù)在我們生活中隨處可見(jiàn);在計(jì)算機(jī)世界,樹(shù)是一種分層結(jié)構(gòu)的抽象模型,
如下圖所示:
樹(shù)結(jié)構(gòu)的應(yīng)用有很多,就比如公司的組織架構(gòu),就可以用樹(shù)來(lái)表示,如下圖:
除了組織架構(gòu),像族譜、省市等都可以使用樹(shù)結(jié)構(gòu)來(lái)表示。
樹(shù)有很多的術(shù)語(yǔ),如下圖:
樹(shù):n(n0)個(gè)節(jié)點(diǎn)所構(gòu)成的有限集合,當(dāng)n=0時(shí),稱(chēng)為空樹(shù);
節(jié)點(diǎn)的度:節(jié)點(diǎn)的子樹(shù)個(gè)數(shù),例如B節(jié)點(diǎn)的度就是2,A節(jié)點(diǎn)的度就是3;
樹(shù)的度:樹(shù)的所有節(jié)點(diǎn)中最大的度數(shù),例如上圖中,樹(shù)的度是3;
葉子節(jié)點(diǎn):度為0的節(jié)點(diǎn),也叫葉節(jié)點(diǎn);
子節(jié)點(diǎn):如上圖;
兄弟節(jié)點(diǎn):如上圖;
根節(jié)點(diǎn):如上圖;
樹(shù)的深度:樹(shù)中所有結(jié)點(diǎn)中的最大層次,例如上圖中樹(shù)的深度就是3;
節(jié)點(diǎn)的層次:例如E節(jié)點(diǎn)的層次就是3,節(jié)點(diǎn)的層次就是父節(jié)點(diǎn)層次+1,根節(jié)點(diǎn)的層次為1;
路徑:一個(gè)節(jié)點(diǎn)到另一個(gè)節(jié)點(diǎn)的通道,例如AH的路徑就是ADH;
路徑長(zhǎng)度:一個(gè)節(jié)點(diǎn)到另一個(gè)節(jié)點(diǎn)的距離,例如AH的路徑就是3。
JavaScript中的樹(shù)
樹(shù)結(jié)構(gòu)可以說(shuō)是前端中最常見(jiàn)的數(shù)據(jù)結(jié)構(gòu)之一,比如說(shuō)DOM樹(shù)、級(jí)聯(lián)選擇、樹(shù)形組件等等;
JavaScript中并沒(méi)有提供樹(shù)這個(gè)數(shù)據(jù)結(jié)構(gòu),但是我們可以通過(guò)對(duì)象和數(shù)組來(lái)模擬一個(gè)樹(shù),
例如下面這段代碼:
consttree={
value:A,
children:[
value:B,
children:[
{value:E,children:null},
{value:F,children:null},
value:C,
children:[{value:G,children:null}],
value:D,
children:[
{value:H,children:null},
{value:I,children:null},
}
廣度優(yōu)先和深度優(yōu)點(diǎn)遍歷算法
所謂的深度優(yōu)先遍歷算法,就是盡可能深的去搜索樹(shù)的分支,它的遍歷順序如下圖:
實(shí)現(xiàn)思路如下:
訪問(wèn)根節(jié)點(diǎn);
對(duì)根節(jié)點(diǎn)的children持續(xù)進(jìn)行深度優(yōu)先遍歷(遞歸);
實(shí)現(xiàn)代碼如下:
functiondfs(root){
console.log(root.value)
root.childrenroot.children.forEach(dfs)//與下面一致
//if(root.children){
//root.children.forEach(child={
//dfs(child)
//})
//}
dfs(tree)//這個(gè)tree就是前面定義的那個(gè)樹(shù)
/*結(jié)果
*/
可以看到,和圖中的順序是一致的,也就是說(shuō)我們的算法沒(méi)有問(wèn)題。
所謂的廣度優(yōu)先就是依次訪問(wèn)離根節(jié)點(diǎn)近的節(jié)點(diǎn),它的遍歷順序如下圖:
實(shí)現(xiàn)思路如下:
創(chuàng)建要給隊(duì)列,把根節(jié)點(diǎn)入隊(duì);
把隊(duì)頭出隊(duì)并訪問(wèn);
把隊(duì)頭的children依次入隊(duì);
重復(fù)執(zhí)行2、3步,直到隊(duì)列為空。
實(shí)現(xiàn)代碼如下:
functionbfs(root){
//1.新建隊(duì)列跟節(jié)點(diǎn)入隊(duì)
constq=[root]
//4重復(fù)執(zhí)行
while(q.length0){
constnode=q.shift()//2隊(duì)頭出隊(duì)
console.log(node.value)
//3隊(duì)頭children依次入隊(duì)
node.children
node.children
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024德州學(xué)院輔導(dǎo)員招聘筆試真題
- 2024成都藝術(shù)職業(yè)大學(xué)輔導(dǎo)員招聘筆試真題
- 法律科技系統(tǒng)運(yùn)維員考試試卷及答案
- 潛水裝備檢測(cè)師筆試試題及答案
- 旅游文創(chuàng)設(shè)計(jì)師筆試試題及答案
- 鍛造車(chē)間設(shè)備點(diǎn)檢員考試試卷及答案
- 2024年杭州拱墅區(qū)武林街道招聘真題
- 指向培養(yǎng)學(xué)生高階思維的小學(xué)英語(yǔ)學(xué)習(xí)單設(shè)計(jì)的案例研究
- 大單元教學(xué):為語(yǔ)文教學(xué)添色增香
- 培養(yǎng)學(xué)生課堂感受力的實(shí)踐與探索
- 山東畜牧獸醫(yī)單招考試題及答案
- 商戶(hù)安全生產(chǎn)培訓(xùn)課件
- 2025年西安高新區(qū)管委會(huì)招聘考試試卷
- 四川省廣元市2024-2025學(xué)年第二學(xué)期八年級(jí)期末考試數(shù)學(xué)試卷(無(wú)答案)
- 2024-2025學(xué)年成都市青羊區(qū)七年級(jí)下英語(yǔ)期末考試題(含答案)
- 死亡病例討論制度落實(shí)與質(zhì)控優(yōu)化
- 痛經(jīng)的中醫(yī)護(hù)理
- 2018-2024年中國(guó)西瓜行業(yè)市場(chǎng)趨勢(shì)分析及投資潛力研究報(bào)告
- DB32∕T 5048-2025 全域土地綜合整治項(xiàng)目驗(yàn)收規(guī)范
- 2025屆河北中考道德與法治真題試卷【含答案】
- 《產(chǎn)科危急重癥早期識(shí)別中國(guó)專(zhuān)家共識(shí)(2024年版)》解讀課件
評(píng)論
0/150
提交評(píng)論