91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么使用二叉樹

發布時間:2021-10-25 11:01:01 來源:億速云 閱讀:121 作者:iii 欄目:web開發

這篇文章主要介紹“怎么使用二叉樹”,在日常操作中,相信很多人在怎么使用二叉樹問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”怎么使用二叉樹”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

「以下以前序遍歷為例:」

「確定遞歸函數的參數和返回值」:因為要打印出前序遍歷節點的數值,所以參數里需要傳入vector在放節點的數值,除了這一點就不需要在處理什么數據了也不需要有返回值,所以遞歸函數返回類型就是void,代碼如下:

void traversal(TreeNode* cur, vector<int>& vec)

「確定終止條件」:在遞歸的過程中,如何算是遞歸結束了呢,當然是當前遍歷的節點是空了,那么本層遞歸就要要結束了,所以如果當前遍歷的這個節點是空,就直接return,代碼如下:

if (cur == NULL) return;

「確定單層遞歸的邏輯」:前序遍歷是中左右的循序,所以在單層遞歸的邏輯,是要先取中節點的數值,代碼如下:

vec.push_back(cur->val);    // 中 traversal(cur->left, vec);  // 左 traversal(cur->right, vec); // 右

單層遞歸的邏輯就是按照中左右的順序來處理的,這樣二叉樹的前序遍歷,基本就寫完了,在看一下完整代碼:

前序遍歷:

class Solution { public:     void traversal(TreeNode* cur, vector<int>& vec) {         if (cur == NULL) return;         vec.push_back(cur->val);    // 中         traversal(cur->left, vec);  // 左         traversal(cur->right, vec); // 右     }     vector<int> preorderTraversal(TreeNode* root) {         vector<int> result;         traversal(root, result);         return result;     } };

那么前序遍歷寫出來之后,中序和后序遍歷就不難理解了,代碼如下:

中序遍歷:

void traversal(TreeNode* cur, vector<int>& vec) {        if (cur == NULL) return;        traversal(cur->left, vec);  // 左        vec.push_back(cur->val);    // 中        traversal(cur->right, vec); // 右    }

后序遍歷:

void traversal(TreeNode* cur, vector<int>& vec) {         if (cur == NULL) return;         traversal(cur->left, vec);  // 左         traversal(cur->right, vec); // 右         vec.push_back(cur->val);    // 中     }

此時大家可以做一做leetcode上三道題目,分別是:

  • 144.二叉樹的前序遍歷

  • 145.二叉樹的后序遍歷

  • 94.二叉樹的中序遍歷

到此,關于“怎么使用二叉樹”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

尚志市| 蓬溪县| 闽清县| 绥中县| 新宾| 洪江市| 龙口市| 磐安县| 威宁| 万荣县| 苏尼特左旗| 台南市| 长兴县| 阳春市| 江口县| 台东市| 馆陶县| 饶河县| 从化市| 桃江县| 惠州市| 兴安县| 巨野县| 诸城市| 台州市| 怀宁县| 玉田县| 甘洛县| 夏津县| 台东市| 黄梅县| 晋城| 榕江县| 枞阳县| 油尖旺区| 商洛市| 霍邱县| 广元市| 达尔| 兴隆县| 合肥市|