102. Binary Tree Level Order Traversal

102. Binary Tree Level Order Traversal

1. 题目

Given a binary tree, return the level order traversal of its nodes’ values. (ie, from left to right, level by level).

For example:
Given binary tree [3,9,20,null,null,15,7],

    3
   / \
  9  20
    /  \
   15   7

return its level order traversal as:

[
  [3],
  [9,20],
  [15,7]
]

2. 解法

二叉树层次遍历最通用的方法是借助队列。C语言没有提供队列接口,因此我们自己实现一个吧。

  • 思路

使用队列实现层次遍历,同时在入队之前统计当前层次节点的个数,在出队时通过出队节点个数来判断是否到下一层。

  • 代码实现:
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */

/*
*   returnSize: 无需分配,用来存放二维数组的行数
*   returnColumnSizes:需要分配空间,用来存放二维数组每一行元素的个数
*   return xxx: 返回的二维数组
*/


# define NodeNum 1024
/**
 * Return an array of arrays of size *returnSize.
 * The sizes of the arrays are returned as *returnColumnSizes array.
 * Note: Both returned array and *columnSizes array must be malloced, assume caller calls free().
 */
int** levelOrder(struct TreeNode* root, int* returnSize, int** returnColumnSizes){
    *returnSize = 0;

    if(NULL == root){
        return NULL;
    }
    int *result = (int *)malloc(sizeof(int) * NodeNum);/*用来存放结果信息*/
    int **resultArray = (int **)malloc(sizeof(int *) * NodeNum);/*用来存放结果信息*/
    *returnColumnSizes = (int *)malloc(sizeof(int) * NodeNum);

    memset(*returnColumnSizes, 0 , sizeof(int) * NodeNum);

    struct TreeNode **queue = (struct TreeNode **)malloc(sizeof(struct TreeNode *) * NodeNum);
    int head=0, rear=0;
    int cnt=0, totalNum=0;
    int layer = 0;
    queue[rear++] = root;

    (*returnColumnSizes)[layer] = 1;
    resultArray[layer] = result + totalNum;

    while(head != rear){/*非空*/
        root = queue[head%NodeNum];
        head++;
        int val = root->val;
        result[totalNum++] = val;
        cnt++;

        if(root->left){
            queue[rear%NodeNum] = root->left;
            rear++;
            (*returnColumnSizes)[layer+1]++;
        }
        if(root->right){
            queue[rear%NodeNum] = root->right;
            rear++;
            (*returnColumnSizes)[layer+1]++;
        }
        if(cnt == (*returnColumnSizes)[layer]){
            cnt=0;
            resultArray[++layer] = result + totalNum;
        }
    }
    *returnSize  = layer;
    return resultArray;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叨陪鲤

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值