欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++二叉樹的前序中序后序非遞歸實現(xiàn)方法詳細講解

 更新時間:2023年03月08日 11:23:25   作者:平凡的人1  
前序遍歷的順序是根、左、右。任何一顆樹都可以認為分為左路節(jié)點,左路節(jié)點的右子樹。先訪問左路節(jié)點,再來訪問左路節(jié)點的右子樹。把訪問左路節(jié)點的右子樹看成一個子問題,就可以完整遞歸訪問了

二叉樹的前序遍歷

前序遍歷的順序是根、左、右。任何一顆樹都可以認為分為左路節(jié)點,左路節(jié)點的右子樹。先訪問左路節(jié)點,再來訪問左路節(jié)點的右子樹。把訪問左路節(jié)點的右子樹看成一個子問題,就可以完整遞歸訪問了。

先定義棧st存放節(jié)點、v存放值,TreeNode* cur,cur初始化為root。

當cur不為空或者棧不為空的時候(一開始棧是空的,cur不為空),循環(huán)繼續(xù):先把左路節(jié)點存放進棧中,同時把值存入v中,一直循環(huán),直到此時的左路節(jié)點為空,訪問結(jié)束。在彈出棧頂元素top,把top->right賦值給我們的cur,就可以轉(zhuǎn)化成子問題去訪問左路節(jié)點的右子樹了。

  • 棧st不為空說明此時還有左路節(jié)點的右子樹還沒訪問,cur不為空說明此時還有樹要去訪問。當兩個同時為空時,循環(huán)結(jié)束,最終得到前序遍歷。
  • 一個節(jié)點出棧說明這個節(jié)點及其左子樹已經(jīng)訪問完了,因為我們是先把左路節(jié)點存入棧中,此時還剩右子樹沒有訪問。
class Solution {
public:
    vector<int> preorderTraversal(TreeNode* root) {
        vector<int> v;
        stack<TreeNode*> st;
        TreeNode*cur = root;
        while(!st.empty()||cur)
        {
            //左路節(jié)點
            while(cur)
            {
                st.push(cur);
                v.push_back(cur->val);
                cur = cur->left;
            }
            //左路節(jié)點右子樹
            TreeNode* top = st.top();
            st.pop();
            cur = top->right;//轉(zhuǎn)化成子問題訪問右子樹
        }
        return v;
    }
};

二叉樹的中序遍歷

中序遍歷是左、根、右。左子樹訪問完之后才能去訪問根。左路節(jié)點一直走直到左子樹訪問完,入棧的過程中不去進行訪問(存放數(shù)值到v中),當左路節(jié)點出棧之后,也就是從棧中彈出進行訪問。

class Solution {
public:
    vector<int> inorderTraversal(TreeNode* root) {
        vector<int> v;
        stack<TreeNode*> st;
        TreeNode*cur = root;
        while(cur||!st.empty())
        {
            while(cur)
            {
                //不訪問
                st.push(cur);
                cur = cur->left;
            }
            TreeNode*top = st.top();
            //進行訪問
            v.push_back(top->val);
            st.pop();
            cur = top->right;
        }
        return v;
    }
};

二叉樹的后序遍歷

后序的遍歷順序是左、右、根。與前面的相比,比較麻煩,我們需要把左子樹和右子樹訪問完再去訪問根。我們定義一個棧,在棧里面取到一個節(jié)點時:右子樹是否訪問過,如果沒有訪問,迭代子問題訪問,如果訪問過了,則訪問這個根節(jié)點,pop出棧

如果top的右子樹為空或者右子樹已經(jīng)訪問過了(上一個訪問節(jié)點是右子樹的根),那么說明右子樹不用訪問或者訪問過了,可以訪問根top;當右子樹不為空,且沒有訪問過,則迭代子問題訪問。

通過prev來判斷上一次訪問的節(jié)點:如果prev等于top->right時,表示棧頂節(jié)點的右子樹已經(jīng)訪問過了,可以彈出棧頂節(jié)點并訪問它。

class Solution {
public:
    vector<int> postorderTraversal(TreeNode* root) {
        vector<int> v;
        stack<TreeNode*> st;
        TreeNode*cur = root;
        TreeNode*prev = nullptr;
        while(cur||!st.empty())
        {
            while(cur)
            {
                st.push(cur);
                cur = cur->left;
            }
            TreeNode*top = st.top();
            //top的右子樹為空,或者右子樹已經(jīng)訪問過了(上一個訪問節(jié)點時右子樹的根)那么說明右子樹不用訪問或者訪問過了,可以訪問根top
            //右子樹不為空,且沒有訪問, 則迭代子問題訪問
            if(top->right==nullptr||top->right==prev)
            {
                st.pop();
                v.push_back(top->val);
                prev = top;
            }
            else
            {
                cur = top->right;
            }
        }
        return v;
    }
};

總結(jié)

二叉樹的前序遍歷、中序遍歷、后序遍歷的非遞歸遍歷三種方法都是類似的,差別在于訪問棧頂?shù)脑氐臅r機不同,訪問控制不同。其中前序和中序大致相同,而后序需要去進行判斷棧頂?shù)挠易訕淝闆r。

到此這篇關(guān)于C++二叉樹的前序中序后序非遞歸實現(xiàn)方法詳細講解的文章就介紹到這了,更多相關(guān)C++二叉樹的前序中序后序?qū)崿F(xiàn)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 一問學(xué)會QT時間類

    一問學(xué)會QT時間類

    QT獲取時間的類有3個,分別是QDate、QTime、QDateTime,他們屬于QT的network模塊。本文詳細的介紹了這3個模塊的使用,感興趣的可以了解一下
    2023-04-04
  • wxWidgets實現(xiàn)圖片和文件按鈕

    wxWidgets實現(xiàn)圖片和文件按鈕

    這篇文章主要為大家詳細介紹了wxWidgets實現(xiàn)圖片和文件按鈕,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-02-02
  • C\C++ 獲取當前路徑實例詳解

    C\C++ 獲取當前路徑實例詳解

    這篇文章主要介紹了C\C++ 獲取當前路徑實例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • C語言循環(huán)結(jié)構(gòu)詳解

    C語言循環(huán)結(jié)構(gòu)詳解

    本文主要介紹C語言循環(huán)結(jié)構(gòu)的基礎(chǔ)知識,這里整理了循環(huán)的基礎(chǔ)資料并附簡單的代碼示例詳細講解,有需要的小伙伴可以參考下
    2021-10-10
  • C++利用SQLite實現(xiàn)命令行工具

    C++利用SQLite實現(xiàn)命令行工具

    這篇文章主要為大家詳細介紹了一個基于 C++、SQLite 和 Boost 庫的簡單交互式數(shù)據(jù)庫操作 Shell,該 Shell 允許用戶通過命令行輸入執(zhí)行各種數(shù)據(jù)庫操作,感興趣的可以了解下
    2023-11-11
  • C++開發(fā)之CRC校驗實例詳解

    C++開發(fā)之CRC校驗實例詳解

    這篇文章主要介紹了C++開發(fā)之CRC校驗實例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • C語言入門的一些基本資源推薦和程序語法概覽

    C語言入門的一些基本資源推薦和程序語法概覽

    這篇文章主要介紹了C語言入門的一些基本資源推薦和程序語法概覽,C語言是很多現(xiàn)代高級編程語言的基礎(chǔ),需要的朋友可以參考下
    2015-12-12
  • 從匯編看c++中變量類型的深入分析

    從匯編看c++中變量類型的深入分析

    本篇文章是對c++中的變量類型進行了詳細的分析介紹。需要的朋友參考下
    2013-05-05
  • C/C++中的?Qt?StandardItemModel?數(shù)據(jù)模型應(yīng)用解析

    C/C++中的?Qt?StandardItemModel?數(shù)據(jù)模型應(yīng)用解析

    QStandardItemModel?是標準的以項數(shù)據(jù)為單位的基于M/V模型的一種標準數(shù)據(jù)管理方式,本文給大家介紹C/C++中的?Qt?StandardItemModel?數(shù)據(jù)模型應(yīng)用解析,感興趣的朋友跟隨小編一起看看吧
    2021-12-12
  • Qt實現(xiàn)手動切換多種布局的完美方案

    Qt實現(xiàn)手動切換多種布局的完美方案

    通過點擊程序界面上不同的布局按鈕,使主工作區(qū)呈現(xiàn)出不同的頁面布局,多個布局之間可以通過點擊不同布局按鈕切換,支持的最多的窗口為9個,不同布局下窗口數(shù)隨之變化,這篇文章主要介紹了Qt實現(xiàn)手動切換多種布局的完美方案,需要的朋友可以參考下
    2024-07-07

最新評論