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

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

文章目录

题目

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

输入格式:

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

输出格式:

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

输入样例:

11

1 2 # 4 # # 3 5 # # #

输出样例:

1

2

4

3

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* index, int n) {
    if (*index >= n || strcmp(tokens[*index], "#") == 0) {
        (*index)++;
        return NULL;
    }
    
    TreeNode* node = createNode(atoi(tokens[*index]));
    (*index)++;
    
    node->left = buildTree(tokens, index, n);
    node->right = buildTree(tokens, index, n);
    
    return node;
}

// 前序遍历二叉树(根-左-右)
void preOrderTraversal(TreeNode* root) {
    if (root == NULL) return;
    
    printf("%d\n", root->data);
    preOrderTraversal(root->left);
    preOrderTraversal(root->right);
}

int main() {
    int n;
    scanf("%d", &n);
    
    // 消耗掉scanf后的换行符
    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");
    }
    
    int index = 0;
    TreeNode* root = buildTree(tokens, &index, n);
    
    preOrderTraversal(root);
    
    return 0;
}
相关推荐
程序员Xu1 分钟前
【LeetCode热题100道笔记】腐烂的橘子
笔记·算法·leetcode
天选之女wow7 分钟前
【代码随想录算法训练营——Day4】链表——24.两两交换链表中的节点、19.删除链表的倒数第N个节点、面试题02.07.链表相交、142.环形链表II
数据结构·算法·leetcode·链表
胡萝卜3.09 分钟前
数据结构初阶:树的相关性质总结
数据结构·二叉树·性质·二叉树的性质
KarrySmile12 分钟前
Day12--HOT100--23. 合并 K 个升序链表,146. LRU 缓存,94. 二叉树的中序遍历
数据结构·链表·二叉树·递归·hot100·lru·灵茶山艾府
恒森宇电子有限公司1 小时前
IP5326_BZ 支持C同口输入输出的移动电源芯片 2.4A的充放电电流 支持4LED指示灯
c语言·开发语言·单片机
THMAIL1 小时前
量化基金从小白到大师 - 金融数据获取大全:从免费API到Tick级数据实战指南
人工智能·python·深度学习·算法·机器学习·金融·kafka
纪元A梦1 小时前
贪心算法应用:数字孪生同步问题详解
java·算法·贪心算法
纪元A梦1 小时前
贪心算法应用:食品生产线排序问题详解
算法·贪心算法
曙曙学编程2 小时前
stm32——NVIC,EXIT
c语言·c++·stm32·单片机·嵌入式硬件
信奥卷王2 小时前
2024年9月GESPC++三级真题解析(含视频)
算法