每日一练(19):从上到下打印二叉树

简介: 从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。

从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。


例如:


给定二叉树: [3,9,20,null,null,15,7],


3

/ \

9  20

/   \

15   7


返回其层次遍历结果:


[
  [3],
  [9,20],
  [15,7]
]


提示:


节点总数 <= 1000


来源:力扣(LeetCode)


链接:https://leetcode-cn.com/probl...


注意的是要把每一层放到一起,需要维护一个level进行保存。


DFS记得使用引用&,不然就得维护一个全局变量了。


方法一:BFS


/**
 * 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>> levelOrder(TreeNode* root) {
        queue<TreeNode*> q;
        q.push(root);
        vector<vector<int>> res;
        while (q.size()) {
            int size = q.size();
            vector<int> level;
            for (int i=0;i<size;i++) {
                TreeNode* rt = q.front();
                q.pop();
                if (!rt) {
                    continue;
                }
                level.push_back(rt->val);
                if (rt->left) {
                    q.push(rt->left);
                }
                if (rt->right) {
                    q.push(rt->right);
                }
            }
            if (level.size()!=NULL) {
                res.push_back(level);
            }
        }
        return res;
    }
};


方法二:DFS


/**
 * 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>> levelOrder(TreeNode* root) {
        vector<vector<int>> res;
        dfs(root, res, 0);
        return res;
    }
    void dfs(TreeNode* root,vector<vector<int>>& res,int level)
    {
        if (!root) {
            return;
        }
        if (level >= res.size()) {
            res.emplace_back(vector<int>());
        }
        res[level].emplace_back(root->val);
        dfs(root->left, res, level+1);
        dfs(root->right, res, level+1);
    }
};
目录
相关文章
|
1月前
|
算法
《剑指offer》之从上到下打印二叉树Ⅰ、Ⅱ、Ⅲ
《剑指offer》之从上到下打印二叉树Ⅰ、Ⅱ、Ⅲ
32 0
|
1月前
|
存储
【剑指offer】- 按之字形顺序打印二叉树-45/67
【剑指offer】- 按之字形顺序打印二叉树-45/67
【剑指offer】-从上往下打印二叉树-22/67
【剑指offer】-从上往下打印二叉树-22/67
|
1月前
|
存储
【剑指offer】-把二叉树打印成多行-43/67
【剑指offer】-把二叉树打印成多行-43/67
剑指offer_二叉树---之字形打印二叉树
剑指offer_二叉树---之字形打印二叉树
42 0
剑指offer 33. 之字形打印二叉树
剑指offer 33. 之字形打印二叉树
54 0
从上到下打印二叉树(简单难度)
从上到下打印二叉树(简单难度)
38 0
从上到下打印二叉树(简单难度)
从上到下打印二叉树 II(简单难度)
从上到下打印二叉树 II(简单难度)
54 0
从上到下打印二叉树 II(简单难度)
|
算法 前端开发 程序员
「LeetCode」剑指Offer-32从上到下打印二叉树 II ⚡️
「LeetCode」剑指Offer-32从上到下打印二叉树 II ⚡️
63 0
「LeetCode」剑指Offer-32从上到下打印二叉树 II ⚡️
|
算法 前端开发 程序员
「LeetCode」剑指Offer-32从上到下打印二叉树 III ⚡️
「LeetCode」剑指Offer-32从上到下打印二叉树 III ⚡️
89 0
「LeetCode」剑指Offer-32从上到下打印二叉树 III ⚡️