【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;
}
相关推荐
艾莉丝努力练剑4 小时前
【数据结构与算法】数据结构初阶:详解顺序表和链表(四)——单链表(下)
c语言·开发语言·数据结构·学习·算法·链表
yngsqq5 小时前
移动碰撞法 ——套料排版算法——CAD c#
算法
笑衬人心。6 小时前
Hashtable 与 HashMap 的区别笔记
java·数据结构·笔记
秋说7 小时前
【PTA数据结构 | C语言版】前序遍历二叉树
c语言·数据结构·算法
会唱歌的小黄李8 小时前
【算法】贪心算法:最大数C++
c++·算法·贪心算法
NuyoahC8 小时前
笔试——Day8
c++·算法·笔试
hy.z_7778 小时前
【数据结构】反射、枚举 和 lambda表达式
android·java·数据结构
墨染点香8 小时前
LeetCode Hot100 【1.两数之和、2.两数相加、3.无重复字符的最长子串】
算法·leetcode·职场和发展
秋说9 小时前
【PTA数据结构 | C语言版】二叉树层序序列化
c语言·数据结构·算法