【PTA数据结构 | C语言版】是不是堆

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

文章目录

题目

给定一个完全二叉树的层序遍历序列,请判断该二叉树是否是二叉堆。

输入格式:

每组测试第 1 行包含 2 个正整数:m (≤100) 是二叉树的个数;n(1<n≤1000)是每个二叉树中结点的个数。随后 m 行,每行给出 n 个不重复的整数键值(均在 32 位整型 int 范围内),是一个完全二叉树的层序遍历序列。

输出格式:

对每个输入中给定的二叉树,如果其对应了一个最大堆,则在一行中输出 Max Heap;如果对应最小堆,则输出 Min Heap;否则输出 Not Heap。随后在下一行输出这棵树的后序遍历序列。一行中的数字间以 1 个空格分隔,行首尾不得有多余空格。

输入样例:

3 8

98 72 86 60 65 12 23 50

8 38 25 58 52 82 70 60

10 28 15 12 34 9 8 56

输出样例:

Max Heap

50 60 65 72 12 23 86 98

Min Heap

60 58 52 38 82 70 25 8

Not Heap

56 12 34 28 9 8 15 10

代码

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

#define MAXN 1001

int tree[MAXN];
int n;

// 判断是否为最大堆
int isMaxHeap() {
    for (int i = 1; i <= n/2; i++) {
        int left = 2 * i;
        int right = 2 * i + 1;
        
        if (left <= n && tree[i] < tree[left]) return 0;
        if (right <= n && tree[i] < tree[right]) return 0;
    }
    return 1;
}

// 判断是否为最小堆
int isMinHeap() {
    for (int i = 1; i <= n/2; i++) {
        int left = 2 * i;
        int right = 2 * i + 1;
        
        if (left <= n && tree[i] > tree[left]) return 0;
        if (right <= n && tree[i] > tree[right]) return 0;
    }
    return 1;
}

// 后序遍历二叉树
void postOrder(int root, int *index, int *result) {
    if (root > n) return;
    
    postOrder(2 * root, index, result);       // 遍历左子树
    postOrder(2 * root + 1, index, result);   // 遍历右子树
    result[(*index)++] = tree[root];          // 访问根节点
}

int main() {
    int m;
    scanf("%d %d", &m, &n);
    
    for (int i = 0; i < m; i++) {
        // 读取层序遍历序列
        for (int j = 1; j <= n; j++) {
            scanf("%d", &tree[j]);
        }
        
        // 判断堆的类型
        if (isMaxHeap()) {
            printf("Max Heap\n");
        } else if (isMinHeap()) {
            printf("Min Heap\n");
        } else {
            printf("Not Heap\n");
        }
        
        // 后序遍历
        int result[MAXN];
        int index = 0;
        postOrder(1, &index, result);
        
        // 输出后序遍历结果
        for (int k = 0; k < n; k++) {
            if (k > 0) printf(" ");
            printf("%d", result[k]);
        }
        printf("\n");
    }
    
    return 0;
}    
相关推荐
耳总是一颗苹果2 小时前
C语言---动态内存管理
c语言·开发语言
仟濹2 小时前
【数据结构】「队列」(顺序队列、链式队列、双端队列)
c语言·数据结构·c++
小苏兮2 小时前
【C语言】字符串与字符函数详解(上)
c语言·开发语言·算法
一只小蒟蒻3 小时前
DFS 迷宫问题 难度:★★★★☆
算法·深度优先·dfs·最短路·迷宫问题·找过程
martian6653 小时前
深入详解随机森林在眼科影像分析中的应用及实现细节
人工智能·算法·随机森林·机器学习·医学影像
apocelipes3 小时前
使用uint64_t批量比较短字符串
c语言·数据结构·c++·算法·性能优化·golang
一只IT攻城狮3 小时前
构建一个简单的Java框架来测量并发执行任务的时间
java·算法·多线程·并发编程
WanderInk3 小时前
在递归中为什么用 `int[]` 而不是 `int`?——揭秘 Java 参数传递的秘密
java·后端·算法
ai小鬼头4 小时前
创业心态崩了?熊哥教你用缺德哲学活得更爽
前端·后端·算法
拾光拾趣录4 小时前
算法 | 下一个更大的排列
前端·算法