剑指 Offer 32 - III. 从上到下打印二叉树 III(BFS)
剑指 Offer 32 - III. 从上到下打印二叉树 III
请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推。
例如:
给定二叉树: [3,9,20,null,null,15,7]
,
3 / \ 9 20 / \ 15 7
返回其层次遍历结果:
[ [3], [20,9], [15,7] ]
提示:
节点总数 <= 1000
1 /** 2 * Definition for a binary tree node. 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 public: 12 vector<vector<int>> levelOrder(TreeNode* root) { 13 vector<vector<int>> ans; 14 if (root == nullptr) { 15 return ans; 16 } 17 queue<TreeNode *> q; 18 q.push(root); 19 int step = 0; 20 while (!q.empty()) { 21 int size = q.size(); 22 vector<int> vec; 23 for (int i = 0; i < size; i++) { 24 TreeNode *curNode = q.front(); 25 q.pop(); 26 if (curNode == nullptr) { 27 continue; 28 } 29 if (curNode->left != nullptr) { 30 q.push(curNode->left); 31 } 32 if (curNode->right != nullptr) { 33 q.push(curNode->right); 34 } 35 vec.push_back(curNode->val); 36 } 37 if (step % 2 == 0) { // 偶数时从左到右 38 ans.push_back(vec); 39 } else { // 奇数时从右到左 40 reverse(vec.begin(), vec.end()); 41 ans.push_back(vec); 42 } 43 step++; 44 } 45 return ans; 46 } 47 };
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理