国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

?算法入門?《二叉樹 - 二叉搜索樹》簡單05 —— LeetCode 897. 遞增順序搜索樹

Soarkey / 1004人閱讀

一、題目

1、題目描述

??給你一棵二叉搜索樹,請按 中序遍歷 將其重新排列為一棵遞增順序搜索樹,使樹中最左邊的節點成為樹的根節點,并且每個節點沒有左子節點,只有一個右子節點。
??樣例輸入: [5,3,6,2,4,null,8,1,null,null,null,7,9]
??樣例輸出: [1,null,2,null,3,null,4,null,5,null,6,null,7,null,8,null,9]

2、基礎框架

  • C語言 版本給出的基礎框架代碼如下:
struct TreeNode* increasingBST(struct TreeNode* root){}

3、原題鏈接

LeetCode 897. 遞增順序搜索樹

二、解題報告

1、思路分析

??1)根據 中序遍歷 的思路,左子樹遍歷完,遍歷根,再遍歷右子樹。加上二叉搜索樹的性質,左子樹所有元素 一定小于 根元素右子樹所有元素 一定大于 根元素
??2)對于 左子樹,需要返回一個 值最小 的結點,讓它指向 根結點;對于 右子樹,需要返回一個 值最大 的結點,并且讓 根結點right指針指向它;
??3)基于上述幾個點,需要提供一個函數,返回一顆子樹的 最小結點最大結點

2、時間復雜度

?? 這是一個遍歷整棵樹的過程,每個結點訪問一次,時間復雜度為 O ( n ) O(n) O(n)。

3、代碼詳解

void findMaxMin(struct TreeNode* root, struct TreeNode** min, struct TreeNode** max) {    struct TreeNode* node = NULL;    struct TreeNode* lmin, *lmax;    struct TreeNode* rmin, *rmax;    if( root == NULL ) {        *min = *max = NULL;                                 // (1)        return ;                                                        }    node = (struct TreeNode *) malloc ( sizeof(struct TreeNode) );    node->val = root->val;                                  // (2)    node->right = NULL;    node->left = NULL;    *min = *max = node;    if(root->left) {                                        // (3)        findMaxMin(root->left, &lmin, &lmax);        lmax->right = node;                                 // (4)        *min = lmin;                                            }    if(root->right) {                                       // (5)        findMaxMin(root->right, &rmin, &rmax);                      node->right = rmin;                                 // (6)        *max = rmax;    }}struct TreeNode* increasingBST(struct TreeNode* root){    struct TreeNode* min;    struct TreeNode* max;    findMaxMin(root, &min, &max);    return min;}
  • ( 1 ) (1) (1) 空樹的情況,minmax都不存在;
  • ( 2 ) (2) (2) 用當前樹根建立一個結點,并且初始化minmax都為這個根結點;
  • ( 3 ) (3) (3) 如果左子樹存在,則尋找左子樹的最小和最大結點;
  • ( 4 ) (4) (4) 將最大結點的right指向當前根結點;
  • ( 5 ) (5) (5) 如果右子樹存在,則尋找右子樹的最小和最大結點;
  • ( 6 ) (6) (6) 將當前結點的right指向 右子樹最小結點的;

三、本題小知識

??二叉樹的 中序遍歷 是指:左子樹遍歷完,遍歷根,再遍歷右子樹。


四、加群須知

??相信看我文章的大多數都是「 大學生 」,能上大學的都是「 精英 」,那么我們自然要「 精益求精 」,如果你還是「 大一 」,那么太好了,你擁有大把時間,當然你可以選擇「 刷劇 」,然而,「 學好算法 」,三年后的你自然「 不能同日而語 」。
??那么這里,我整理了「 幾十個基礎算法 」 的分類,點擊開啟:

?《算法入門指引》?

??如果鏈接被屏蔽,或者有權限問題,可以私聊作者解決。

??大致題集一覽:





??為了讓這件事情變得有趣,以及「 照顧初學者 」,目前題目只開放最簡單的算法 「 枚舉系列 」 (包括:線性枚舉、雙指針、前綴和、二分枚舉、三分枚舉),當有 一半成員刷完 「 枚舉系列 」 的所有題以后,會開放下個章節,等這套題全部刷完,你還在群里,那么你就會成為「 夜深人靜寫算法 」專家團 的一員。
??不要小看這個專家團,三年之后,你將會是別人 望塵莫及 的存在。如果要加入,可以聯系我,考慮到大家都是學生, 沒有「 主要經濟來源 」,在你成為神的路上,「 不會索取任何 」。
???聯系作者,或者掃作者主頁二維碼加群,加入刷題行列吧?


?讓天下沒有難學的算法?

C語言免費動漫教程,和我一起打卡!
?《光天化日學C語言》?

入門級C語言真題匯總
?《C語言入門100例》?

幾張動圖學會一種數據結構
?《畫解數據結構》?

組團學習,抱團生長
?《算法入門指引》?

競賽選手金典圖文教程
?《夜深人靜寫算法》?

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/119807.html

相關文章

  • LeetCode 專項】把二叉搜索轉換為累加(538)

    摘要:解法一中序遍歷分析由于給定了二叉搜索樹,因此首先考慮中序遍歷,使用示例,我們先來分別看一下二叉搜索樹和累加樹中序遍歷的結果二叉搜索樹二叉累加樹。這里還是使用示例,我們再來觀察一下二叉搜索樹和累加樹中序遍歷的結果二叉搜索樹二叉累加樹。 ...

    xcold 評論0 收藏0
  • Leetcode打卡——二叉搜索(共8題)

    摘要:也就是說,有個節點的平衡二叉搜索樹,它的高度是。以搜索操作為例,如果二叉搜索樹的高度為,則時間復雜度為。二叉搜索樹的高度的確很重要。樹集合,中的或者中的,是由高度平衡的二叉搜索樹實現的。 ...

    Olivia 評論0 收藏0
  • 通過幾道題目學習二叉搜索

    摘要:根據這個特征,用二分法來將有序數組轉換為一顆二叉搜索樹。邊界條件向下取整得到中間值遞歸二分法接下來我們驗證下一棵樹是否滿足二叉搜索樹。二驗證二叉搜索樹相關題目驗證二叉搜索樹中等思路就是,中序遍歷如果滿足遞增的就行。 二叉樹大家都知道,二叉搜索樹滿足以下特征: 節點的左子樹只包含小于當前節點的數節點的右子樹只包含大于當前節點的數 所有左子樹和右子樹自身必須也是二叉搜索樹 二叉搜索樹也叫...

    Steven 評論0 收藏0
  • 前端 | 每天一個 LeetCode

    摘要:在線網站地址我的微信公眾號完整題目列表從年月日起,每天更新一題,順序從易到難,目前已更新個題。這是項目地址歡迎一起交流學習。 這篇文章記錄我練習的 LeetCode 題目,語言 JavaScript。 在線網站:https://cattle.w3fun.com GitHub 地址:https://github.com/swpuLeo/ca...我的微信公眾號: showImg(htt...

    張漢慶 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<