【剑斩OFFER】算法的暴力美学——leetCode 103 题:二叉树的锯齿形层序遍历

一、题目描述

二、算法原理

思路:在层序遍历的基础上添加一个标志位。

层序遍历的算法实现:

https://blog.csdn.net/2403_84958571/article/details/156873549?spm=1011.2415.3001.10575&sharefrom=mp_manage_link

标志位:

三、代码实现

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) {
        if(root == nullptr) return {};
        queue<TreeNode*> que;//队列辅助实现层序遍历
        vector<vector<int>> ret;//最终的结果
        int num = 0;
        que.push(root);
        bool flag = false;//标志位,fase:标识不用逆转数组
        while(!que.empty())
        {
            vector<int> tmp;
            num = que.size();
            while(num--)
            {
                TreeNode* node = que.front();
                tmp.push_back(node->val);
                if(node->left)
                    que.push(node->left);
                if(node->right)
                    que.push(node->right);
                que.pop();
            }
            if(flag)//flag = true
            {
                //逆转数组
                reverse(tmp.begin(),tmp.end());
                flag = false;//下一轮就不用逆转了
            }
            else flag = true;
            ret.push_back(tmp);
        }
        return ret;
    }
};
相关推荐
故事和你915 小时前
洛谷-算法2-3-分治与倍增5
开发语言·数据结构·c++·算法·动态规划·图论
北顾笙9805 小时前
day37-数据结构力扣
数据结构·算法·leetcode
啦啦啦_99995 小时前
1. 逻辑回归
算法·机器学习·逻辑回归
fengenrong6 小时前
20260429
c++·算法
南宫萧幕6 小时前
Python与Simulink联合仿真:基于DQN的HEV能量管理策略建模与全链路排雷实战
开发语言·人工智能·python·算法·机器学习·matlab·控制
apollowing6 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(优)
算法·启发式算法·web app
Chat_zhanggong3457 小时前
主推NT98336BG作用有哪些?
嵌入式硬件·算法
Run_Teenage7 小时前
算法:线段树
算法
Westward-sun.7 小时前
YOLOv2算法全方位解析:从BatchNorm到聚类先验框的九大改进
算法·yolo·聚类
扶苏xw7 小时前
【离散化算法】
算法