1、題目描述
請(qǐng)實(shí)現(xiàn)一個(gè)函數(shù)按照之字形順序從上向下打印二叉樹(shù)。
即第一行按照從左到右的順序打印,第二層按照從右到左的順序打印,第三行再按照從左到右的順序打印,其他行以此類(lèi)推。
樣例
輸入如下圖所示二叉樹(shù)[8, 12, 2, null, null, 6, 4, null, null, null, null]
??8
? / ?\
12 2
??? / ?\
? 6 ? 4
輸出:[[8], [2, 12], [6, 4]]
2、問(wèn)題描述:
- 之字形打印二叉樹(shù)。
3、問(wèn)題關(guān)鍵:
- 層次打印,再加一個(gè)標(biāo)記,每次,反轉(zhuǎn)一下就可以了。
4、C++代碼:
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
vector<vector<int>> printFromTopToBottom(TreeNode* root) {
vector<vector<int>> res;
if (!root) return res;
queue<TreeNode*> q;
q.push(root);
q.push(nullptr);
bool flag = true;//為true,正向打印,false反向打印。
vector<int> level;//保存每層遍歷的結(jié)果。
while(q.size()) {
auto t = q.front();
q.pop();
if (t) {//如果當(dāng)前層結(jié)束標(biāo)記就加入level中。
level.push_back(t->val);
if (t->left) q.push(t->left);
if (t->right) q.push(t->right);
}
else {//如果當(dāng)前層遍歷完了,那么就將結(jié)果加入res中。
if (level.empty()) break;//說(shuō)明把所有層都遍歷完了。
if (flag) {//正向打印。
res.push_back(level);
flag = false;
}
else {
res.push_back(vector<int>(level.rbegin(), level.rend()));
flag = true;
}
level.clear();
q.push(nullptr);//為下一層的最后加入標(biāo)記。
}
}
return res;
}
};