【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;
}
相关推荐
2301_79516720几秒前
玩转Rust高级应用 如何理解 Rust 实现免疫数据竞争的关键是Send 和 Sync 这两个 trait
开发语言·算法·rust
Blossom.118几秒前
AI Agent记忆系统深度实现:从短期记忆到长期人格的演进
人工智能·python·深度学习·算法·决策树·机器学习·copilot
贩卖黄昏的熊2 分钟前
数据结构示例代码
数据结构
Q741_14724 分钟前
C++ 面试高频考点 链表 迭代 递归 力扣 25. K 个一组翻转链表 每日一题 题解
c++·算法·链表·面试·递归·迭代
_fairyland1 小时前
数据结构 力扣 练习
数据结构·考研·算法·leetcode
Neil今天也要学习1 小时前
永磁同步电机无速度算法--基于三阶LESO的反电动势观测器
算法·1024程序员节
机器学习之心1 小时前
NGO-VMD北方苍鹰算法优化变分模态分解+皮尔逊系数+小波阈值降噪+信号重构,MATLAB代码
算法·matlab·重构·信号重构·ngo-vmd·皮尔逊系数·小波阈值降噪
橘颂TA1 小时前
【剑斩OFFER】算法的暴力美学——山脉数组的蜂顶索引
算法·leetcode·职场和发展·c/c++
速易达网络2 小时前
C语言常见推理题
java·c语言·算法
沪漂的码农2 小时前
C语言队列与链表结合应用完整指南
c语言·链表