leetcode算法(199.二叉树的右视图)

层序遍历的时候,判断是否遍历到单层的最后面的元素,如果是,就放进result数组中,随后返回result就可以了。

cpp 复制代码
class Solution {
public:
    vector<int> rightSideView(TreeNode* root) {
        // 创建一个队列用于BFS层序遍历
        queue<TreeNode*> que;
        
        // 如果根节点不为空,将其加入队列
        if (root != NULL) que.push(root);
        
        // 存储结果的向量,将保存二叉树的右视图
        vector<int> result;
        
        // 当队列不为空时,继续遍历
        while (!que.empty()) {
            // 获取当前层的节点数量
            int size = que.size();
            
            // 遍历当前层的所有节点
            for (int i = 0; i < size; i++) {
                // 取出队首节点
                TreeNode* node = que.front();
                que.pop();
                
                // 如果是当前层的最后一个节点(最右侧节点),将其值加入结果
                // 因为队列是先进先出,所以最后一个节点就是该层最右边的节点
                if (i == (size - 1)) result.push_back(node->val);
                
                // 将当前节点的左子节点加入队列(如果存在)
                if (node->left) que.push(node->left);
                
                // 将当前节点的右子节点加入队列(如果存在)
                if (node->right) que.push(node->right);
            }
        }
        
        // 返回右视图结果
        return result;
    }
};
相关推荐
算法-大模型备案 多米11 分钟前
算法备案算法安全自评估报告模板(精简完善版)
大数据·网络·人工智能·算法·文心一言
Frostnova丶14 分钟前
LeetCode 238 & 2906.构造乘积数组与乘积矩阵
算法·leetcode·矩阵
张槊哲17 分钟前
拆解大语言模型(LLM)的底层推演、架构演进与工业落地
算法
sali-tec28 分钟前
C# 基于OpenCv的视觉工作流-章41-模板匹配
图像处理·人工智能·opencv·算法·计算机视觉
进击的小头35 分钟前
第16篇:系统的稳定裕度分析
python·算法
黎阳之光1 小时前
AI数智筑防线 绿色科技启新篇,如何用硬核技术赋能生态安全双升级
人工智能·科技·算法·安全·数字孪生
2201_758642641 小时前
自定义内存检测工具
开发语言·c++·算法
Westward-sun.1 小时前
矿物分类实战(一):从异常值到标准化——数据清洗全流程拆解
人工智能·算法·机器学习·数据清洗
D_C_tyu1 小时前
HTML | 结合Canvas开发具有智能寻路功能的贪吃蛇小游戏实战详解
javascript·算法·游戏·html·bfs
小王不爱笑1321 小时前
HashMap 扩容全流程
java·数据结构·算法