堆排序算法——C
2021/4/17 20:25:36
本文主要是介绍堆排序算法——C,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
原始数据:array[]={49,38,65,97,76,13,27,49,10}
1.原始堆排序
2.创建大顶堆
3.开始排序(从小到大),交换根节点和最后一个结点。
4.重新创建大顶堆,进行下一结点的排序。循环即可。
5.五个函数
交换函数:void swap(int array[],int x,int y)
初始化大顶堆函数:void BuildHeap(int array[],int size)
生成大顶堆函数:void Down(int array[],int i,int n)
排序函数:void heapSort(int array[],int size)
主函数:int main()
#include <stdio.h> void display(int array[], int size) { for (int i = 0; i < size; i++) { printf("%d ", array[i]); } printf("\n"); } void swap(int array[], int x, int y) { int key = array[x]; array[x] = array[y]; array[y] = key; } // 从大到小排序 // void Down(int array[], int i, int n) { // int child = 2 * i + 1; // int key = array[i]; // while (child < n) { // if (child + 1 < n && array[child] > array[child + 1]) { // child++; // } // if (key > array[child]) { // swap(array, i, child); // i = child; // } else { // break; // } // child = child * 2 + 1; // } // } // 从小到大排序 void Down(int array[], int i, int n) { // 最后结果就是大顶堆 int parent = i; // 父节点下标 int child = 2 * i + 1; // 子节点下标 while (child < n) { if (child + 1 < n && array[child] < array[child + 1]) { // 判断子节点那个大,大的与父节点比较 child++; } if (array[parent] < array[child]) { // 判断父节点是否小于子节点 swap(array, parent, child); // 交换父节点和子节点 parent = child; // 子节点下标 赋给 父节点下标 } child = child * 2 + 1; // 换行,比较下面的父节点和子节点 } } void BuildHeap(int array[], int size) { for (int i = size / 2 - 1; i >= 0; i--) { // 倒数第二排开始, 创建大顶堆,必须从下往上比较 Down(array, i, size); // 否则有的不符合大顶堆定义 } } void HeapSort(int array[], int size) { printf("初始化数组:"); BuildHeap(array, size); // 初始化堆 display(array, size); // 查看初始化结果 for (int i = size - 1; i > 0; i--) { swap(array, 0, i); // 交换顶点和第 i 个数据 // 因为只有array[0]改变,其它都符合大顶堆的定义,所以可以从上往下重新建立 Down(array, 0, i); // 重新建立大顶堆 printf("排序的数组:"); display(array, size); } } int main() { int array[] = {49, 38, 65, 97, 76, 13, 27, 49, 10}; int size = sizeof(array) / sizeof(int); // 打印数据 printf("%d \n", size); printf("排序前数组:"); display(array, size); HeapSort(array, size); return 0; }
这篇关于堆排序算法——C的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南
- 2025-01-03图像文字理解,OCR、大模型还是多模态模型?PalliGema2在QLoRA技术上的微调与应用
- 2025-01-03混合搜索:用LanceDB实现语义和关键词结合的搜索技术(应用于实际项目)
- 2025-01-03停止思考数据管道,开始构建数据平台:介绍Analytics Engineering Framework
- 2025-01-03如果 Azure-Samples/aks-store-demo 使用了 Score 会怎样?
- 2025-01-03Apache Flink概述:实时数据处理的利器
- 2025-01-01使用 SVN合并操作时,怎么解决冲突的情况?-icode9专业技术文章分享