LeetCode Algorithm 530. 二叉搜索树的最小绝对差
生活随笔
收集整理的這篇文章主要介紹了
LeetCode Algorithm 530. 二叉搜索树的最小绝对差
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
530. 二叉搜索樹的最小絕對差
Ideas
前幾天一直刷鏈表題,這道題剛看到的時候還有點懵,第一個想到的方法竟然是全排列,腦子瓦特了。
二叉樹的題目基本上都得跟(前/中/后)序遍歷扯點關系,一看是沒注意二叉搜索樹這個信息,導致一直沒想明白,還是從例子中發現這是二叉搜索樹的。
二叉搜索樹的中序遍歷是一個升序的序列,那么所有元素的最小絕對差其實就是相鄰兩個元素差的最小值。
然后直接默寫二叉樹中序遍歷模板,修改一下輸出邏輯部分就OK了。
Code
C++
class Solution { public:int middle_order_traversal(TreeNode* node) {if (!node) {return 0;}int pre = -1, ans = INT_MAX;stack<TreeNode*> sta;TreeNode* item = node;while (!sta.empty() || item != nullptr) {if (item != nullptr) {sta.push(item);item = item->left;} else {item = sta.top();if (pre == -1) {pre = item->val;} else {ans = min(ans, item->val - pre);pre = item->val;}sta.pop();item = item->right;}}return ans; } int getMinimumDifference(TreeNode* root) {return middle_order_traversal(root);} };總結
以上是生活随笔為你收集整理的LeetCode Algorithm 530. 二叉搜索树的最小绝对差的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: LeetCode Algorithm 剑
- 下一篇: LeetCode Algorithm 5