色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

java - 一段遞歸代碼的問題

瀏覽:82日期:2024-01-08 16:29:44

問題描述

在一篇博客上看到了一個遞歸函數,但我感覺劃線的那一行似乎永遠不為true呢?

java - 一段遞歸代碼的問題

因為函數里的第一個判斷條件:

if (!root || p == root || q == root) return root;

就決定了left必定是p,q,null之一吧?

我對遞歸的理解不太深刻,不知道理解的對不對?謝謝。

問題解答

回答1:

首先你要弄明白,這個遞歸函數的返回值有4種可能:

null,表示這次遞歸已經碰到葉子節點,無法再繼續下去了。

p,表示這次遞歸已經碰到p節點了。

q,表示這次遞歸已經碰到q節點了。

lowestCommonAncestor,表示已經找到的最低公共祖先節點。

為何這樣說,前3種可能,你應該很好理解,因為從<1> if (!root || p == root || q == root) return root;這行代碼可以看出來。

那么再看(我就簡寫了)<2> left = lowestCommonAncestor(left, p, q);<3> right = lowestCommonAncestor(right, p, q);這兩行。在真正的lowestCommonAncestor被找到之前,這個函數只可能會返回null,q,p。再看這兩行判斷<4> if (left && left != p && left != q) return left;<5> if (right && right != p && right != q) return right;當<2>,<3>兩處的返回值是null,p,q的時候,這兩處判斷的條件都無法滿足,所以不會返回。所以要進入再下面的判斷<6> if (left && right) return root;這句什么意思?如果從<4>,<5>的判斷處沒有返回,說明left和right只能是null,p,q中的一個,而這里了又限定了left和right必須是非null,意思就是這時候left和right必定一個是p,一個是q。那么這個時候,本層遞歸函數的root(注意是本層遞歸函數)就是那個lowestCommonAncesstor,于是就返回它。最后一句<7> return left ? left : right;既然到了這里,就說明left和right里面至少有一個是null,那么就返回非null的那個,或者如果兩個都是null就返回null。

現在倒回去再看一下lowestCommonAncesstor這個遞歸函數在<2>,<3>兩處的調用,你可以把它看成是去當前節點的left和right中分別去尋找p,和q,那么無非結果有4種:

返回null,說明p,q根本不在這個分支中。

返回p,說明這個分支中只有p,沒有q。

返回q,說明這個分支中只有q,沒有p。

返回lowestCommonAncesstor,說明這個分支中既有p又有q,于是就已經找到他們的公共祖先啦!

可能說的還是不夠透徹,希望對你有幫助:)

回答2:

第一個條件是判斷root,第二個是判斷left,有什么聯系嗎?

標簽: java
相關文章:
主站蜘蛛池模板: 亚洲国产成+人+综合 | 精品一区二区在线观看 | 亚洲国产精品久久久久久网站 | 国产高清一区二区三区视频 | 日本红怡院亚洲红怡院最新 | 三级国产在线 | 国产欧美在线不卡 | 久久香蕉国产精品一区二区三 | 在线观看亚洲 | 国产在线一区二区三区四区 | 亚洲国产二区三区久久 | 日日狠狠久久偷偷四色综合免费 | 91探花福利精品国产自产在线 | 一级毛片不卡片免费观看 | 日本亚洲综合 | 美女三级毛片 | 精品成人网 | 国产黄色在线网站 | 欧美视频一区二区专区 | 成人午夜做爰视频免费看 | 国产日本亚洲欧美 | 日韩欧美中文字幕在线观看 | 成人a级高清视频在线观看 成人a毛片 | 一级国产交换配乱淫 | 久久精品综合 | 性欧美另类老妇高清 | 欧美在线做爰高清视频 | 精品400部自拍视频在线播放 | 日韩在线视频不卡一区二区三区 | a毛片免费全部播放完整成 a毛片免费全部在线播放毛 | 黄色网址亚洲 | 国产91一区二区在线播放不卡 | 精品一久久 | 欧美人成一本免费观看视频 | 黄色三级毛片 | 尹人香蕉久久99天天拍 | 欧美精品v日韩精品v国产精品 | 在线视频欧美日韩 | 免费一级a毛片在线播放视 免费一级α片在线观看 | 孩交啪啪网址 | 国产成人精品男人免费 |