算法进阶——按之字形顺序打印二叉树

文章描述了一种算法,用于解决给定二叉树的之字形层序遍历问题,使用两个栈实现,奇数层从左向右,偶数层从右向左。时间复杂度和空间复杂度均为O(n)。
摘要由CSDN通过智能技术生成

题目


给定一个二叉树,返回该二叉树的之字形层序遍历,(第一层从左向右,下一层从右向左,一直这样交替)。

数据范围:0≤n≤1500,树上每个节点的val满足∣val∣<=1500

要求:空间复杂度:O(n),时间复杂度:O(n)

例如:
给定的二叉树是{1,2,3,#,#,4,5}

该二叉树之字形层序遍历的结果是
[
[1],
[3,2],
[4,5]
]

示例1

输入:
{1,2,3,#,#,4,5}
返回值:
[[1],[3,2],[4,5]]
说明:
如题面解释,第一层是根节点,从左到右打印结果,第二层从右到左,第三层从左到右。

示例2

输入:
{8,6,10,5,7,9,11}
返回值:
[[8],[10,6],[5,7,9,11]]

示例3

输入:
{1,2,3,4,5}
返回值:
[[1],[3,2],[4,5]]

思路


用两个辅助栈,通过层序遍历二叉树,需要注意的是因为奇数层要从左往右打印,所以前一个偶数层入栈需要先右后左,偶数层正好相反。

总结规律就是奇数层先左后右入栈,偶数层先右后左入栈。

解答代码


/**
 * struct TreeNode {
 *	int val;
 *	struct TreeNode *left;
 *	struct TreeNode *right;
 *	TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 * };
 */
#include <stack>
#include <vector>
class Solution {
public:
    /**
     * @param pRoot TreeNode类 
     * @return int整型vector<vector<>>
     */
    vector<vector<int> > Print(TreeNode* pRoot) {
        // write code here
        vector<vector<int> > res{};
        if (pRoot == nullptr) {
            return res;
        }

        stack<TreeNode*> odd_level;// 奇数层,从左往右打印
        stack<TreeNode*> even_level;// 偶数层,从右往左打印
        int cur = 1;// 当前层索引
        odd_level.push(pRoot);

        vector<int> tmp;
        while (!odd_level.empty() || !even_level.empty()) {
            if ((cur&1) == 1) {
                // 奇数层
                auto size = odd_level.size();
                for (int i = 0; i < size; i++) {
                    auto node = odd_level.top();
                    tmp.push_back(node->val);

                    // 先左后右
                    if (node->left != nullptr) {
                        even_level.push(node->left);
                    }
                    if (node->right != nullptr) {
                        even_level.push(node->right);
                    }

                    odd_level.pop();
                }
            } else {
                // 偶数层
                auto size = even_level.size();
                for (int i = 0; i < size; i++) {
                    auto node = even_level.top();
                    tmp.push_back(node->val);

                    // 先右后左
                    if (node->right != nullptr) {
                        odd_level.push(node->right);
                    }
                    if (node->left != nullptr) {
                        odd_level.push(node->left);
                    }

                    even_level.pop();
                }
            }
            ++cur;
            res.push_back(tmp);
            tmp.clear();
        }

        return res;
    }
};
  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这里是一个按前序遍历打印二叉树叶子节点的算法: 1. 如果树为空,返回。 2. 如果节点是叶子节点,打印该节点的值。 3. 递归遍历节点的左子树。 4. 递归遍历节点的右子树。 这个算法会先检查树是否为空,如果是空树则直接返回。如果节点是叶子节点,也就是该节点既没有左子节点也没有右子节点,则打印该节点的值。接着递归遍历节点的左子树和右子树,分别执行步骤2到步骤4,直到遍历完整棵树。 这个算法的时间复杂度是O(n),其中n是树中节点的个数。因为该算法需要遍历整棵树一次,对于每个节点最多执行常数次操作。你好!要按照设计算法的前序遍历顺序打印二叉树的叶子节点,可以使用递归来实现。具体步骤如下: 1. 如果当前节点为空,直接返回。 2. 如果当前节点是叶子节点(即左右子节点都为空),打印该节点的值。 3. 递归遍历当前节点的左子树。 4. 递归遍历当前节点的右子树。 下面是中文的示例代码: ``` class TreeNode: def __init__(self, val=0, left=None, right=None): self.val = val self.left = left self.right = right def print_leaves(root): if not root: return if not root.left and not root.right: print(root.val) print_leaves(root.left) print_leaves(root.right) ``` 你可以使用这个函数来打印二叉树的叶子节点。例如,对于下面的二叉树: ``` 1 / \ 2 3 / \ \ 4 5 6 ``` 按照前序遍历的顺序,叶子节点的顺序为 4, 5, 6,因此使用上述代码打印输出的结果为: ``` 4 5 6 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值