【无标题】

#include <stdio.h>

// 交换函数

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

int temp = *a;

*a = *b;

*b = temp;

}

// 堆化函数

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

int largest = i;

int left = 2 * i + 1;

int right = 2 * i + 2;

if (left < n && arr[left] > arr[largest]) {

largest = left;

}

if (right < n && arr[right] > arr[largest]) {

largest = right;

}

if (largest!= i) {

swap(&arr[i], &arr[largest]);

heapify(arr, largest, n);

}

}

// 构建最大堆

void buildMaxHeap(int arr[], int n) {

int i = (n - 1) / 2;

while (i >= 0) {

heapify(arr, i, n);

i--;

}

}

// 堆排序函数

void heapSort(int arr[], int n) {

buildMaxHeap(arr, n);

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

swap(&arr[0], &arr[i]);

heapify(arr, 0, i);

}

}

// 打印数组函数

void printArray(int arr[], int size) {

for (int i = 0; i < size; i++)

printf("%d ", arr[i]);

printf("\n");

}

// 测试案例

int main() {

int arr[] = {12, 11, 13, 5, 6};

int size = sizeof(arr) / sizeof(arr[0]);

printf("排序前的数组为:\n");

printArray(arr, size);

heapSort(arr, size);

printf("排序后的数组为:\n");

printArray(arr, size);

return 0;

}

相关推荐
Scc_hy3 分钟前
强化学习_Paper_1988_Learning to predict by the methods of temporal differences
人工智能·深度学习·算法
巷北夜未央4 分钟前
Python每日一题(14)
开发语言·python·算法
javaisC6 分钟前
c语言数据结构--------拓扑排序和逆拓扑排序(Kahn算法和DFS算法实现)
c语言·算法·深度优先
爱爬山的老虎6 分钟前
【面试经典150题】LeetCode121·买卖股票最佳时机
数据结构·算法·leetcode·面试·职场和发展
SWHL7 分钟前
rapidocr 2.x系列正式发布
算法
雾月5532 分钟前
LeetCode 914 卡牌分组
java·开发语言·算法·leetcode·职场和发展
想跑步的小弱鸡35 分钟前
Leetcode hot 100(day 4)
算法·leetcode·职场和发展
Fantasydg36 分钟前
DAY 35 leetcode 202--哈希表.快乐数
算法·leetcode·散列表
jyyyx的算法博客37 分钟前
Leetcode 2337 -- 双指针 | 脑筋急转弯
算法·leetcode
SweetCode1 小时前
裴蜀定理:整数解的奥秘
数据结构·python·线性代数·算法·机器学习