二叉搜尋樹

2021-10-06 03:22:27 字數 360 閱讀 9361

如果 p 大於當前節點的值,說明後繼節點一定在右子樹

如果 p 等於當前節點的值,說明後繼節點一定在右子樹

如果 p 小於當前節點的值,說明後繼節點一定在左子樹或自己就是

遞迴呼叫左樹,如果是空的,說明當前節點就是答案,否則已在左樹中找到答案

class

solution

};

突然想到這其實就是中序遍歷。如果左樹中存在乙個大於p的節點即可直接返回。遍歷開始先去左樹中尋找,如果找到就返回,此時這個點必然是大於p節點最小的那個。找不到就取右樹中找。

class

solution

};

二叉搜尋樹 二叉搜尋樹

題目 二叉搜尋樹 time limit 2000 1000 ms j a others memory limit 32768 32768 k j a others total submission s 6945 accepted submission s 3077 problem descripti...

二叉搜尋樹 修剪二叉搜尋樹

第一反應是重構,看來別人的解答發現,其實不用重構那麼複雜。treenode trimbst treenode root,int low,int high if root val high 下一層處理完左子樹的結果賦給root left,處理完右子樹的結果賦給root right。root left ...

樹 二叉樹 二叉搜尋樹

給定乙個二叉樹,判斷其是否是乙個有效的二叉搜尋樹。假設乙個二叉搜尋樹具有如下特徵 節點的左子樹只包含小於當前節點的數。節點的右子樹只包含大於當前節點的數。所有左子樹和右子樹自身必須也是二叉搜尋樹。示例 1 輸入 2 13輸出 true 示例 2 輸入 5 14 3 6輸出 false 解釋 輸入為 ...