优选算法_锯齿形层序遍历二叉树_队列_C++

一.题目解析

就相当于蛇形遍历二叉树

算法解析:

二.代码编写:

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    vector<vector<int>> zigzagLevelOrder(TreeNode* root) {
        vector<vector<int>>ret;
        if(root==nullptr)return ret;
        queue<TreeNode*>q;
        q.push(root);
        int level=1;
        while(!q.empty())
        {
            int sz=q.size();
            vector<int>tmp;
            
            for(int i=0;i<sz;i++)
            {
                TreeNode*t=q.front();
                q.pop();
                tmp.push_back(t->val);

                if(t->left)q.push(t->left);//左右孩子要入队
                if(t->right)q.push(t->right);
            }
            if(level%2==0)reverse(tmp.begin(),tmp.end());
            level++;
            ret.push_back(tmp);
        }
        return ret;
    }
};
相关推荐
王哈哈^_^5 分钟前
【源码教程+数据集】农作物分类检测数据集 10712 张,农作物分类检测系统实战教程
人工智能·算法·yolo·目标检测·计算机视觉·毕业设计·数据集
兰令水12 分钟前
leecodecode【回溯子集】【2026.6.4打卡-java版本】
java·开发语言·深度优先
bubiyoushang88812 分钟前
基于 C/C++ 的 MQTT 物联网通信协议实现
c语言·c++·物联网
fox_lht14 分钟前
14.3.重构
开发语言·后端·rust
FuckPatience25 分钟前
C# new List<T>(IEnumerable<T> collection),链表初始化时传入已存在链表
链表·c#·list
牛油果子哥q33 分钟前
【C++ const 】全场景深度精讲:修饰规则、底层常量折叠、指针 / 引用 / 成员函数实战、易错坑点与工程代码实现
开发语言·c++
bIo7lyA8v34 分钟前
算法优化中的多线程数据一致性问题的技术8
算法
東隅已逝,桑榆非晚35 分钟前
数据结构:算法效率与复杂度分析详解
数据结构·笔记·算法
闪电悠米37 分钟前
黑马点评-Redisson-02_reentrant_lock
java·spring boot·redis·分布式·缓存