日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

LeetCode Algorithm 530. 二叉搜索树的最小绝对差

發布時間:2024/5/17 编程问答 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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. 二叉搜索树的最小绝对差的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。