【PTA数据结构 | C语言版】根据层序序列重构二叉树

本专栏持续输出数据结构题目集,欢迎订阅。

文章目录

题目

请编写程序,根据给定二叉树的层序序列化结果,重构二叉树,并输出其层序遍历结果。

输入格式:

输入首先给出一个不超 20 的正整数 n,随后一行给出 n 个层序序列的元素。其中键值都是不超过 9 位的正整数,空结点对应符号 #。

输出格式:

输出二叉树的层序遍历结果,每个数字占一行。

输入样例:

11

1 2 3 # 4 5 # # # # #

输出样例:

1

2

3

4

5

代码

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef struct TreeNode {
    int data;
    struct TreeNode *left;
    struct TreeNode *right;
} TreeNode;

TreeNode* createNode(int data) {
    TreeNode* node = (TreeNode*)malloc(sizeof(TreeNode));
    node->data = data;
    node->left = NULL;
    node->right = NULL;
    return node;
}

TreeNode* buildTree(char** tokens, int n) {
    if (n == 0 || strcmp(tokens[0], "#") == 0) return NULL;
    
    TreeNode* root = createNode(atoi(tokens[0]));
    TreeNode* queue[1000];
    int front = 0, rear = 0;
    queue[rear++] = root;
    
    int i = 1;
    while (i < n && front < rear) {
        TreeNode* current = queue[front++];
        
        // 处理左子节点
        if (i < n && strcmp(tokens[i], "#") != 0) {
            current->left = createNode(atoi(tokens[i]));
            queue[rear++] = current->left;
        }
        i++;
        
        // 处理右子节点
        if (i < n && strcmp(tokens[i], "#") != 0) {
            current->right = createNode(atoi(tokens[i]));
            queue[rear++] = current->right;
        }
        i++;
    }
    
    return root;
}

void levelOrderTraversal(TreeNode* root) {
    if (root == NULL) return;
    
    TreeNode* queue[1000];
    int front = 0, rear = 0;
    queue[rear++] = root;
    
    while (front < rear) {
        TreeNode* current = queue[front++];
        printf("%d\n", current->data);
        
        if (current->left != NULL) queue[rear++] = current->left;
        if (current->right != NULL) queue[rear++] = current->right;
    }
}

void freeTree(TreeNode* root) {
    if (root == NULL) return;
    freeTree(root->left);
    freeTree(root->right);
    free(root);
}

int main() {
    int n;
    scanf("%d", &n);
    getchar();  // 消耗换行符
    
    char input[1000];
    fgets(input, sizeof(input), stdin);
    
    char* tokens[100];
    int count = 0;
    char* token = strtok(input, " \n");
    
    while (token != NULL && count < n) {
        tokens[count++] = token;
        token = strtok(NULL, " \n");
    }
    
    TreeNode* root = buildTree(tokens, n);
    levelOrderTraversal(root);
    freeTree(root);
    
    return 0;
}
相关推荐
快去睡觉~2 分钟前
力扣190:颠倒二进制位
数据结构·算法·leetcode
惯导马工13 分钟前
【论文导读】CTIN: Robust Contextual Transformer Network for Inertial Navigation
算法
草莓熊Lotso33 分钟前
【C++】详解形参和实参:别再傻傻分不清
c语言·开发语言·c++·经验分享·笔记·其他
骑驴看星星a38 分钟前
皮尔逊相关(Pearson)和斯皮尔曼相关(Spearman)显著性检验
算法·数学建模·回归·线性回归
翻滚丷大头鱼1 小时前
android View详解—自定义ViewGroup,流式布局
android·数据结构
MT_1251 小时前
大小端存储的理解与判断方法
数据结构·算法
玩镜的码农小师兄1 小时前
[从零开始面试算法] (11/100) LeetCode 226. 反转二叉树:递归的“镜像”魔法
c++·算法·leetcode·面试·递归·hot100
喜欢吃豆2 小时前
LangGraph 深度解析(三):构建可观测、交互式 AI 智能体的流式架构权威指南
人工智能·python·算法·架构·大模型
玉木子4 小时前
机器学习(六)朴素贝叶斯分类
开发语言·人工智能·python·算法·机器学习·分类
明月(Alioo)5 小时前
机器学习进阶,一文搞定模型选型!
人工智能·算法·机器学习