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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

LeetCode Binary Tree Level Order Traversal

發布時間:2024/10/12 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 LeetCode Binary Tree Level Order Traversal 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Given a binary tree, return the?level order?traversal of its nodes' values. (ie, from left to right, level by level).

For example:
Given binary tree?{3,9,20,#,#,15,7},

DFS遍歷方法:

1 /** 2 * Definition for binary tree 3 * struct TreeNode { 4 * int val; 5 * TreeNode *left; 6 * TreeNode *right; 7 * TreeNode(int x) : val(x), left(NULL), right(NULL) {} 8 * }; 9 */ 10 class Solution { 11 private: 12 vector<vector<int> > ret; 13 public: 14 void solve(int dep, TreeNode *root) 15 { 16 if (root == NULL) 17 return; 18 19 if (ret.size() > dep) 20 { 21 ret[dep].push_back(root->val); 22 } 23 else 24 { 25 vector<int> a; 26 a.push_back(root->val); 27 ret.push_back(a); 28 } 29 30 solve(dep + 1, root->left); 31 solve(dep + 1, root->right); 32 } 33 34 vector<vector<int> > levelOrder(TreeNode *root) { 35 // Start typing your C/C++ solution below 36 // DO NOT write int main() function 37 ret.clear(); 38 solve(0, root); 39 40 return ret; 41 } 42 };

?

BFS遍歷打印

1 /** 2 * Definition for binary tree 3 * struct TreeNode { 4 * int val; 5 * TreeNode *left; 6 * TreeNode *right; 7 * TreeNode(int x) : val(x), left(NULL), right(NULL) {} 8 * }; 9 */ 10 11 struct Node 12 { 13 TreeNode *node; 14 int level; 15 Node(){} 16 Node(TreeNode *n, int l):node(n), level(l){} 17 }; 18 19 class Solution { 20 private: 21 vector<vector<int> > ret; 22 public: 23 vector<vector<int> > levelOrder(TreeNode *root) { 24 // Start typing your C/C++ solution below 25 // DO NOT write int main() function 26 ret.clear(); 27 28 if (root == NULL) 29 return ret; 30 31 queue<Node> q; 32 33 q.push(Node(root, 0)); 34 35 vector<int> a; 36 int curLevel = -1; 37 38 while(!q.empty()) 39 { 40 Node node = q.front(); 41 if (node.node->left) 42 q.push(Node(node.node->left, node.level + 1)); 43 if (node.node->right) 44 q.push(Node(node.node->right, node.level + 1)); 45 46 if (curLevel != node.level) 47 { 48 if (curLevel != -1) 49 ret.push_back(a); 50 curLevel = node.level; 51 a.clear(); 52 a.push_back(node.node->val); 53 } 54 else 55 a.push_back(node.node->val); 56 57 q.pop(); 58 } 59 60 ret.push_back(a); 61 62 return ret; 63 } 64 };

轉載于:https://www.cnblogs.com/chkkch/archive/2012/10/27/2742955.html

總結

以上是生活随笔為你收集整理的LeetCode Binary Tree Level Order Traversal的全部內容,希望文章能夠幫你解決所遇到的問題。

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