堆的基础操作,C语言示例

#include <stdio.h>

#include <stdlib.h>

#define MAX_SIZE 100 // 堆的最大容量

// 交换两个元素

void swap(int* a, int* b) {

int temp = *a;

*a = *b;

*b = temp;

}

// 堆调整(向下调整,维护大顶堆)

void heapify(int arr\[\], int n, int i) {

int largest = i; // 假设当前节点是最大值

int left = 2 * i + 1; // 左子节点索引

int right = 2 * i + 2; // 右子节点索引

if (left < n && arrleft > arrlargest)

largest = left;

if (right < n && arrright > arrlargest)

largest = right;

if (largest != i) {

swap(&arri, &arrlargest);

heapify(arr, n, largest); // 递归调整子树

}

}

// 创建大顶堆

void buildHeap(int arr\[\], int n) {

// 从最后一个非叶子节点开始向前调整

for (int i = n / 2 - 1; i >= 0; i--) {

heapify(arr, n, i);

}

}

// 插入元素

void insert(int arr\[\], int* n, int value) {

if (*n >= MAX_SIZE) {

printf("堆已满,无法插入!\n");

return;

}

// 新元素放到末尾,再向上调整

arr\*n = value;

int i = *n;

(*n)++;

// 与父节点比较,大于则交换

while (i > 0 && arri > arr(i - 1) / 2) {

swap(&arri, &arr(i - 1) / 2);

i = (i - 1) / 2;

}

}

// 删除堆顶元素

void deleteTop(int arr\[\], int* n) {

if (*n <= 0) {

printf("堆为空,无法删除!\n");

return;

}

// 用最后一个元素替换堆顶,再向下调整

arr0 = arr\*n - 1;

(*n)--;

heapify(arr, *n, 0);

}

// 获取堆顶元素

int getTop(int arr\[\], int n) {

if (n <= 0) {

printf("堆为空!\n");

return -1; // 无效值标记

}

return arr0;

}

// 修改堆中元素

void updateValue(int arr\[\], int n, int index, int newValue) {

if (index < 0 || index >= n) {

printf("索引无效!\n");

return;

}

int oldValue = arrindex;

arrindex = newValue;

if (newValue > oldValue) {

// 新值更大,向上调整

while (index > 0 && arrindex > arr(index - 1) / 2) {

swap(&arrindex, &arr(index - 1) / 2);

index = (index - 1) / 2;

}

} else {

// 新值更小,向下调整

heapify(arr, n, index);

}

}

// 判断堆是否为空

int isEmpty(int n) {

return n == 0;

}

// 打印堆

void printHeap(int arr\[\], int n) {

if (isEmpty(n)) {

printf("堆为空\n");

return;

}

for (int i = 0; i < n; i++) {

printf("%d ", arri);

}

printf("\n");

}

int main() {

int heapMAX_SIZE; // 存储堆的数组

int size = 0; // 当前堆的大小

// 演示1:插入元素

printf("=== 插入元素 ===\n");

insert(heap, &size, 10);

insert(heap, &size, 30);

insert(heap, &size, 20);

insert(heap, &size, 50);

insert(heap, &size, 40);

printf("插入后堆的内容:");

printHeap(heap, size); // 输出:50 40 20 10 30

// 演示2:获取堆顶元素

printf("\n=== 获取堆顶 ===\n");

printf("当前堆顶(最大值):%d\n", getTop(heap, size)); // 输出:50

// 演示3:删除堆顶

printf("\n=== 删除堆顶 ===\n");

deleteTop(heap, &size);

printf("删除后堆的内容:");

printHeap(heap, size); // 输出:40 30 20 10

// 演示4:修改元素

printf("\n=== 修改元素 ===\n");

printf("将索引2的元素(值为20)修改为60:\n");

updateValue(heap, size, 2, 60);

printf("修改后堆的内容:");

printHeap(heap, size); // 输出:60 30 40 10(因为60>20,向上调整)

// 演示5:用无序数组创建堆

printf("\n=== 用无序数组创建堆 ===\n");

int arr\[\] = {1, 3, 2, 5, 4};

int n = 5;

buildHeap(arr, n);

printf("创建的堆内容:");

printHeap(arr, n); // 输出:5 4 2 3 1

return 0;

}

相关推荐
重生之后端学习几秒前
Java入门
java·开发语言·职场和发展
碧海蓝天20226 分钟前
C++法则24:在标准 C++ 中,没有任何可移植的方式判断指针 T* pt 指向的内存位置是否已经 构造了对象,程序员必须手动跟踪哪些元素已构造。
java·开发语言·c++
老余捞鱼18 分钟前
线性回归实战:5步验证你的量化因子是否真有效
算法·金融·回归·线性回归·ai量化
想吃火锅100521 分钟前
【leetcode】121.买卖股票的最佳时机js/c++
算法·leetcode·职场和发展
один but you42 分钟前
const和constexpr常量表达式
java·前端·javascript
码云数智-大飞44 分钟前
RAII 与智能指针深度拆解
java·前端·算法
Dick5071 小时前
ROS2 常用命令表
人工智能·学习·算法·机器人
云烟成雨TD1 小时前
Agent Scope Java 2.x 系列【19】Harness:从零搭建 MySQL 文件系统
java·人工智能·agent
qq3621967051 小时前
阿里裁员新消息(2026最新动态汇总)
java·开发语言·前端
a1117761 小时前
“黑夜流星“个人引导页 网页html
java·前端·html