中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

怎么使用二叉樹

發布時間: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

吴桥县| 芮城县| 马鞍山市| 石林| 孝义市| 邹城市| 游戏| 余庆县| 贡觉县| 增城市| 石屏县| 邹城市| 滨海县| 武邑县| 浦北县| 柘荣县| 卢龙县| 长宁县| 建德市| 岗巴县| 横峰县| 平安县| 泰安市| 新龙县| 吕梁市| 垦利县| 万州区| 双柏县| 鸡西市| 宝清县| 明溪县| 安徽省| 修武县| 余干县| 佳木斯市| 湘乡市| 沾化县| 荥阳市| 宁安市| 如皋市| 娱乐|