【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;
}
相关推荐
zy_destiny几秒前
【工业场景】用YOLOv26实现4种输电线隐患检测
人工智能·深度学习·算法·yolo·机器学习·计算机视觉·输电线隐患识别
鲨辣椒100861 分钟前
二叉树代码变现——递归函数实现深度遍历
数据结构
智驱力人工智能10 分钟前
货车违规变道检测 高速公路安全治理的工程实践 货车变道检测 高速公路货车违规变道抓拍系统 城市快速路货车压实线识别方案
人工智能·opencv·算法·安全·yolo·目标检测·边缘计算
罗湖老棍子14 分钟前
【例9.18】合并石子(信息学奥赛一本通- P1274)从暴搜到区间 DP:石子合并的四种写法
算法·动态规划·区间dp·区间动态规划
dgaf16 分钟前
【疯狂的往左】用 C 语言播放《下山》
c语言·c++
2301_8107301022 分钟前
python第四次作业
数据结构·python·算法
adam_life25 分钟前
区间动态# P1880 [NOI1995] 石子合并】
算法
坠金31 分钟前
递归、递归和回溯的区别
算法
春栀怡铃声35 分钟前
认识二叉树~
c语言·数据结构·经验分享·c·编译
恋爱绝缘体135 分钟前
Java语言提供了八种基本类型。六种数字类型【函数基数噶】
java·python·算法