精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

二叉樹中和為某一值的路徑

開發 前端
按照前序遍歷的順序去訪問這顆二叉樹,在訪問節點10之后,就會訪問節點5。圖中二叉樹并沒有指向父節點的指針,當訪問節點5的時候,我們是不知道前面經過了哪些節點的,此時我們就需要準備一個棧,用來存儲訪問過的節點。

思路分析

我們舉例來做分析,如下圖所示,我們準備了一顆二叉樹和一個整數22,通過觀察后,我們很容易就能看出它有兩條路徑的節點值加起來和為22。

  • 10、5、7
  • 10、12

圖片

上述兩個路徑都是從根節點出發到葉子節點的,也就是說路徑總是以根節點為起始點,因此我們首先需要遍歷根節點。在樹的三種遍歷方式中,只有前序遍歷是首先訪問根節點的。

按照前序遍歷的順序去訪問這顆二叉樹,在訪問節點10之后,就會訪問節點5。圖中二叉樹并沒有指向父節點的指針,當訪問節點5的時候,我們是不知道前面經過了哪些節點的,此時我們就需要準備一個棧,用來存儲訪問過的節點。

當到達節點5的時候,路徑中包含兩個節點:10、5。接下來遍歷到節點4,我們把這個節點入棧,這時候已經到達葉節點,但棧中的所有節點之和是19。這個和不等于輸入的值22,因此它不符合要求的路徑。

最后,我們要遍歷的節點是12。在遍歷這個節點之前,需要先經過節點5回到節點10。同樣的,每次當從子節點回到父節點的時候,我們都需要在路徑上刪除子節點。最后在節點10到達節點12的時候,路徑上的兩個節點的值之和也是22,因此這也是一條符合要求的路徑。

  • 分析到這里,我們就找到了一些規律:
  • 當用前序遍歷的方式訪問到某一節點時,就把該節點添加到路徑上,并累加該節點的值
  • 如果該節點為葉節點,并且路徑中節點值的和剛好等于輸入的整數,則當前路徑符合要求
  • 如果該節點非葉節點,則繼續訪問它的子節點。從節點路徑棧中刪除當前節點

遞歸上述過程,直至二叉樹的所有節點訪問完畢。

圖片

實現代碼

形成了清晰的思路之后,接下來我們就可以輕松的寫出代碼了,如下所示:

  • 聲明需要的變量:已訪問過的路徑棧、滿足預期的路徑數組、當前已訪問節點的值總和
  • 從root節點開始,用前序遍歷訪問所有節點,篩選并存儲滿足預期條件的路徑
  findPath(root: Node<number>, expectedSum: number): Array<string> {
if (root == null) return [];

// 用一個棧來存儲訪問過的路徑
const pathStack = new Stack();
// 存儲符合條件的路徑
const pathList: Array<string> = [];
// 當前已訪問路徑總和
const currentSum = 0;
// 從root節點開始搜索節點
this.searchNode(root, expectedSum, pathStack, currentSum, pathList);
return pathList;
}
  • 取出根節點的值,將其進行累加
  • 累加后,將根節點的值壓入路徑棧中
  • 判斷是否訪問到了葉節點,如果為葉節點且當前已訪問的節點路徑總和等于預期條件則將路徑棧中的路徑放入符合條件的路徑數組中
  • 當前節點非葉節點,則繼續遞歸訪問它的左、右子樹
  • 左、右子樹都訪問完成后,則代表當前路徑不滿足預期條件,將其從路徑棧中出棧
private searchNode(
root: Node<number>,
expectedSum: number,
pathStack: Stack,
currentSum: number,
pathList: Array<string>
) {
// 累加當前已訪問節點的和,將當前節點入棧
currentSum += root.key;
pathStack.push(root.key);

// 如果是葉節點,并且路徑上節點值的和等于輸入的值,則存儲當前路徑棧中的節點
const isLeaf = root.left == null && root.right == null;
if (currentSum == expectedSum && isLeaf) {
pathList.push(pathStack.toString());
}
// 非葉子節點,則遍歷它的子節點
if (root.left != null) {
this.searchNode(root.left, expectedSum, pathStack, currentSum, pathList);
}
if (root.right != null) {
this.searchNode(root.right, expectedSum, pathStack, currentSum, pathList);
}

// 當前節點不符合條件,將其出棧
pathStack.pop();
}

測試用例

接下來我們用文章開頭的例子來測試下上述代碼能否正確執行。

const tree: Node<number> = {
key: 10,
left: {
key: 5,
left: {
key: 4
},
right: {
key: 7
}
},
right: {
key: 12
}
};
const targetVal = 22;
const resultPath = treeOperateTest.findPath(tree, targetVal);
console.log(resultPath);

如下所示,成功得計算出了兩條路徑。

圖片

我們將節點12改成20,再來測試下,結果如下所示,只有一條路徑符合預期。

圖片

示例代碼

本文用到的代碼完整版請移步:

  • TreeOperate.ts
  • TreeOperate-test.ts
責任編輯:武曉燕 來源: 神奇的程序員
相關推薦

2021-12-05 18:25:12

二叉樹路徑節點

2020-04-27 07:05:58

二叉樹左子樹右子樹

2021-05-06 17:46:30

二叉樹數據結構

2021-04-19 07:47:42

數據結構二叉樹Tree

2021-04-20 08:37:14

數據結構二叉樹

2021-04-28 20:12:27

數據結構創建

2022-10-26 23:58:02

二叉樹數組算法

2021-11-29 10:40:58

二叉樹鏡像節點

2021-08-27 11:36:44

二叉樹回溯節點

2021-03-17 08:19:22

二叉樹LeetCode

2013-07-15 16:35:55

二叉樹迭代器

2021-09-29 10:19:00

算法平衡二叉樹

2021-12-17 14:26:58

二叉樹節點數量

2021-08-06 11:34:05

二叉樹遞歸回溯

2020-09-23 18:25:40

算法二叉樹多叉樹

2022-07-27 07:45:53

二叉樹鏡像函數

2018-03-15 08:31:57

二叉樹存儲結構

2021-10-12 09:25:11

二叉樹樹形結構

2021-09-15 07:56:32

二叉樹層次遍歷

2022-10-12 23:25:17

二叉樹父節點根節點
點贊
收藏

51CTO技術棧公眾號

亚洲嫩草精品久久| 中文视频一区| 欧美唯美清纯偷拍| 在线观看免费91| 国产成人精品白浆久久69| 中文日韩欧美| 色婷婷综合久久久久| av av在线| 高清不卡av| 亚洲日本在线观看| 欧美激情视频一区二区三区| 国产成a人亚洲精v品无码| 久久国产精品99国产| 久久国产精品影视| 制服 丝袜 综合 日韩 欧美| 国产一区二区三区亚洲综合| 色八戒一区二区三区| www.99riav| 成人在线观看黄色| www.亚洲色图.com| 3d动漫啪啪精品一区二区免费| 午夜婷婷在线观看| 国产精品xvideos88| 夜夜躁日日躁狠狠久久88av| 捆绑裸体绳奴bdsm亚洲| 精品一区91| 欧美日韩视频在线一区二区| 丰满少妇被猛烈进入高清播放| 黄色成人在线| 欧美极品美女视频| 久久久久资源| 蜜桃久久一区二区三区| 精品一区二区三区影院在线午夜| 欧美中文在线观看| 久久午夜免费视频| 尹人成人综合网| 欧美成人剧情片在线观看| 成人无码精品1区2区3区免费看| 亚洲国产欧美日韩在线观看第一区| 欧美不卡一二三| 亚洲天堂一区二区在线观看| 国产精品久久久久久久久久齐齐| 色呦呦日韩精品| 亚洲中文字幕无码不卡电影| www.51av欧美视频| 精品福利樱桃av导航| www成人免费| 青草在线视频| 亚洲一区二区成人在线观看| 日本免费a视频| 大黄网站在线观看| 一级中文字幕一区二区| 激情五月婷婷六月| 3d玉蒲团在线观看| 亚洲影视在线播放| 毛片在线播放视频| 深夜av在线| 一本大道久久a久久综合| 欧美激情国产精品日韩| 国产精品专区免费| 欧美亚洲禁片免费| 国内国产精品天干天干| 免费一级欧美在线大片| 精品区一区二区| 国产精品久久AV无码| 日韩精品福利一区二区三区| 亚洲精品影视在线观看| 国产99在线 | 亚洲| 欧美成人自拍| 久久69精品久久久久久国产越南| 日本五十路女优| 久久婷婷一区| 国产欧美最新羞羞视频在线观看| 96日本xxxxxⅹxxx17| 国产精品一区二区在线看| 国产超碰91| 欧美一区二区视频| 国产精品欧美一级免费| 久久精品在线免费视频| 成人三级高清视频在线看| 欧美视频二区36p| 国产原创精品在线| 成人av综合网| 一区二区福利视频| 唐朝av高清盛宴| 一区二区动漫| 成人午夜激情免费视频| 欧美 中文字幕| 国产精品蜜臀av| 国产青草视频在线观看| 视频二区不卡| 日韩欧美国产精品一区| 99久久人妻无码精品系列| 91精品精品| 国产91精品久久久久| 一区二区精品视频在线观看| 成人动漫一区二区在线| 色姑娘综合av| 97人人爽人人澡人人精品| 欧美日韩中文字幕精品| 亚洲天堂av网站| 99久久婷婷这里只有精品 | 精品视频一区二区| 天天影视久久综合| 日韩欧美999| 色婷婷狠狠18禁久久| 国产剧情在线观看一区| 色综合久久悠悠| 一级久久久久久| 不卡的av网站| 懂色av粉嫩av蜜臀av| gay欧美网站| 欧美tk丨vk视频| 国精产品一区一区二区三区mba| 国产美女精品| 国产精品毛片va一区二区三区| 91caoporn在线| 欧美午夜激情在线| 在线播放av网址| 91亚洲国产高清| 国产精品久久国产精品99gif| 日本xxxxwww| 亚洲精品日日夜夜| 四季av一区二区三区| 韩日一区二区三区| 欧美在线播放视频| 色婷婷av一区二区三| 一区二区三区欧美激情| xxww在线观看| 欧美色就是色| 国产精品18久久久久久首页狼| 天天操天天干天天爱| 亚洲狠狠爱一区二区三区| 日韩精品在线播放视频| 天天综合亚洲| 成人免费xxxxx在线观看| av中文字幕一区二区三区| 色偷偷一区二区三区| 亚洲永久无码7777kkk| 亚洲人妖在线| 好看的日韩精品| 高潮在线视频| 亚洲国产精品悠悠久久琪琪| 日本天堂网在线观看| 99久久伊人精品| 黄色国产一级视频| 人妖一区二区三区| 日本精品久久久久久久| 国产一二三区在线| 欧美三级电影在线看| 国精产品视频一二二区| 精品中文av资源站在线观看| 国产精品美女在线播放| 亚洲精品在线播放| 午夜精品久久久久久久99热浪潮 | 亚洲人成电影网站色www| 久久99国产综合精品免费| 久久久久亚洲综合| 日本肉体xxxx裸体xxx免费| 四虎8848精品成人免费网站| 成人免费午夜电影| 羞羞污视频在线观看| 亚洲国产日韩精品在线| 精品国产一区二区三区四| 久久久欧美精品sm网站| 天天干天天av| 亚洲激情影院| 日本一区二区高清视频| 久久精品嫩草影院| 欧美成人激情在线| 无码国产精品一区二区免费16| 日韩欧美中文在线| 国产精品夜夜夜爽阿娇| 国产91精品露脸国语对白| 每日在线更新av| 成人羞羞网站| 超碰97在线资源| 成人美女黄网站| 久久天天躁日日躁| 无码精品一区二区三区在线| 在线视频你懂得一区| 手机av在线看| 91偷拍与自偷拍精品| 日韩一级免费片| 日韩午夜av| 伊人久久av导航| 国产精品网址| 国产欧美一区二区三区在线 | 一区二区日韩欧美| 久久久久天天天天| 成人精品在线| 欧美综合在线观看| av在线看片| 亚洲视频axxx| 亚洲精品久久久久久久久久 | 午夜影院免费体验区| 欧美视频在线一区二区三区| 久久久久久久久精| 中文字幕欧美激情| 青青草视频网站| 裸体一区二区三区| 黄色动漫网站入口| 欧美日韩亚洲国产精品| 天堂av一区二区| 久久久久久毛片免费看| 91精品视频网站| japanese23hdxxxx日韩| 久久久久久久久爱| 国产精品va在线观看视色| 亚洲欧洲日产国码av系列天堂| 不卡视频免费在线观看| 欧美视频在线观看一区| 亚洲s码欧洲m码国产av| 亚洲成人精品一区| 国产免费无码一区二区视频| 国产精品青草久久| 亚洲久久久久久久| 99精品欧美一区二区蜜桃免费| 亚洲一区二区三区三州| 麻豆传媒一区二区三区| 久久九九国产视频| 亚洲作爱视频| 精品少妇在线视频| 欧美日韩18| 亚洲mv在线看| 成人情趣视频网站| 日韩精品一区二区三区四区五区| 老司机成人在线| 国产伦精品一区二区| 一区二区网站| 99porn视频在线| 亚洲乱码一区| 91国产在线免费观看| 91成人在线网站| 91精品免费视频| 欧洲午夜精品| 成人午夜黄色影院| 精品午夜视频| 爱情岛论坛亚洲入口| avtt综合网| 国产精品亚洲综合| 免费福利视频一区| 精选一区二区三区四区五区| 日韩av中文字幕一区| 精品欧美国产一区二区三区不卡| 麻豆精品少妇| 美女黄毛**国产精品啪啪| 中文天堂资源在线| 久久爱.com| 国产精品电影网| 另类图片综合电影| 国产成+人+综合+亚洲欧洲 | 日本高清精品| 99久久精品免费看国产四区| 91精品啪在线观看国产手机 | 天堂在线视频观看| 亚洲精品www| 精品成人一区二区三区免费视频| 亚洲欧美在线x视频| 九一国产在线| 日韩亚洲在线观看| 影音先锋男人资源在线| 久久99久久99精品免观看粉嫩| 乱插在线www| 欧美一区二区色| 成人h在线观看| 亚洲free性xxxx护士hd| 国产精品videossex| 欧美福利精品| 手机在线一区二区三区| 黄色激情在线视频| 男女精品网站| 中文字幕第一页在线视频| 国产不卡视频在线观看| 在线 丝袜 欧美 日韩 制服| 国产精品每日更新在线播放网址| 精品国产欧美日韩不卡在线观看| 午夜日韩在线电影| 五月婷婷丁香在线| 日韩视频中午一区| 欧美91精品久久久久国产性生爱| 最近2019中文字幕第三页视频| 污污影院在线观看| 国产成人aa精品一区在线播放| 少妇高潮一区二区三区99| 国产精品亚洲不卡a| 色综合咪咪久久网| 亚洲国产精品无码观看久久| 日欧美一区二区| 肉丝美足丝袜一区二区三区四| 久久嫩草精品久久久精品| 丰满少妇被猛烈进入一区二区| 欧美三级xxx| 国产suv一区二区| 亚洲网站在线观看| 日本无删减在线| 国产日韩欧美中文| 日韩免费电影在线观看| a级网站在线观看| 日韩av中文在线观看| 无码人妻一区二区三区一| 亚洲国产精品高清| 九九热在线视频播放| 欧美一区二区三区免费大片| 国产在线免费观看| 18一19gay欧美视频网站| 国产成年精品| 热舞福利精品大尺度视频| 亚洲午夜伦理| 婷婷激情小说网| 欧美国产丝袜视频| 丰满少妇乱子伦精品看片| 日韩一区二区不卡| 天堂地址在线www| 国产成人福利网站| 免费观看成人www动漫视频| 奇米777四色影视在线看| 美国十次了思思久久精品导航| 免费的av网站| 亚洲国产精品尤物yw在线观看| 国产精品久久久久久免费播放| 国产午夜精品一区理论片飘花| av在线加勒比| 国产精品.com| 午夜亚洲福利| 手机看片国产精品| 一色桃子久久精品亚洲| 中文字幕一区二区三区免费看| 亚洲人成在线免费观看| 三级在线观看视频| 精品一区二区国产| 亚洲茄子视频| 亚洲一区二区三区无码久久| 亚洲国产一区二区三区| 丰满人妻一区二区三区免费| 欧美黑人性猛交| 日日夜夜精品视频| www.avtt| www.亚洲色图| 国产一级精品视频| 日韩极品精品视频免费观看| 岛国在线视频网站| 久久99蜜桃综合影院免费观看| 国产精品日本欧美一区二区三区| 国产a级黄色片| 天天影视涩香欲综合网| 天天干天天爽天天操| 欧洲美女7788成人免费视频| 九九精品在线| 少妇黄色一级片| 国产精品二三区| 99精品久久久久久中文字幕| 欧美成人中文字幕| 盗摄牛牛av影视一区二区| 黄页网站在线观看视频| 久久一区二区三区四区| www.com亚洲| 日韩亚洲在线观看| 1204国产成人精品视频| 久久免费视频3| 国产午夜精品久久久久久久| 国产一级片免费视频| www国产91| 99re91这里只有精品| 欧美日韩在线视频一区二区三区| 久久久久国产精品人| 最近中文字幕在线视频| 久久天天躁狠狠躁夜夜爽蜜月| 精品人人人人| 超碰在线97免费| 亚洲欧美日韩一区二区| 色综合免费视频| 国产精品入口日韩视频大尺度| 在线国产一区| 北岛玲一区二区| 欧美日韩精品一二三区| 欧美xxxx少妇| 日本一区二区精品视频| 国产麻豆日韩欧美久久| 男人的天堂一区| 最近2019年好看中文字幕视频| 大型av综合网站| 国产91色在线观看| 亚洲国产精品视频| 在线视频自拍| 国外成人在线视频网站| 美日韩一级片在线观看| 国产在线观看免费av| 中文字幕日韩精品在线| 国产极品模特精品一二| 手机看片一级片| 精品人伦一区二区三区蜜桃免费| 在线免费黄色| 久久er99热精品一区二区三区| 精品亚洲成a人在线观看 | 久久狠狠一本精品综合网| 性欧美videos| 亚洲一级黄色av| 另类ts人妖一区二区三区| 天天操精品视频|