leetcode做题笔记102. 二叉树的层序遍历

给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。

思路一:递归

cpp 复制代码
int** levelOrder(struct TreeNode* root, int* returnSize, int** returnColumnSizes){
    int** ans=(int**)malloc(sizeof(int*)*2000);
    *returnSize=0;
    if(!root) return NULL;
    int columnSizes[3000];
    struct TreeNode* queue[3000];
    int rear=0;int head=0;
    queue[rear++]=root;

    while(rear!=head){
        ans[(*returnSize)]=(int*)malloc(sizeof(int)*(rear-head));
        columnSizes[(*returnSize)]=rear-head;
        int start=head;
        head=rear;
        for(int i=start;i<head;i++){
            ans[(*returnSize)][i-start]=queue[i]->val;
            if(queue[i]->left) queue[rear++]=queue[i]->left;
            if(queue[i]->right) queue[rear++]=queue[i]->right;
        }
        (*returnSize)++;
       
    }
    *returnColumnSizes=(int*)malloc(sizeof(int)*(*returnSize));
    for(int i=0;i<*returnSize;i++) (*returnColumnSizes)[i]=columnSizes[i];
    return ans;
}

分析:

本题要求二叉树的层序遍历,可想到使用BFS算法,将二叉树每层放入数组中最后输出数组,可想到利用队列插入队尾删除队首的特性模拟队列记录每层的数再输出

总结:

本题考察二叉树的层序遍历,利用队列的特性可以解决

相关推荐
一定要AK1 分钟前
JVM 全体系深度解析笔记
java·jvm·笔记
ambition202422 分钟前
【算法详解】飞机降落问题:DFS剪枝解决调度问题
c语言·数据结构·c++·算法·深度优先·图搜索算法
徒 花9 分钟前
Python知识学习08
java·python·算法
chushiyunen9 分钟前
milvus笔记、常用表结构
笔记·算法·milvus
YunQuality15 分钟前
六西格玛黑带三个月拿证经验分享
笔记·职场和发展·职场·学习方法
liliangcsdn20 分钟前
ChromaDB距离计算公式示例
人工智能·算法·机器学习
人道领域21 分钟前
【LeetCode刷题日记】242.字母异位词
算法·leetcode·职场和发展
QDYOKR16826 分钟前
一文了解什么是OKR
大数据·人工智能·笔记·钉钉·企业微信
ZhiqianXia28 分钟前
PyTorch 学习笔记(12):ATen C++ 算子引擎的完整架构之旅
pytorch·笔记·学习
卖男孩的小火柴.30 分钟前
java内置方法总结及基础算法
java·算法