考研数据结构——C语言实现大顶堆

堆排序是一种高效的比较类算法,它利用了二叉堆数据结构。下面是代码的详细解释:

  1. #include <stdio.h>#include <stdlib.h> 是预处理指令,用于引入标准输入输出库和标准库,这样我们就可以调用 printf 和其他标准函数。

  2. int arr[] 定义了一个整型数组,其中包含了需要排序的元素。

  3. int n = sizeof(arr) / sizeof(arr[0]); 计算数组 arr 的长度。

  4. void adjustHeap(int i, int lef) 函数用于调整堆,以维护大顶堆的性质。它接受两个参数:i 是当前需要调整的节点的索引,lef 是堆中元素的总数。

    • int temp = arr[i]; 保存当前节点的值,以便在调整过程中进行比较和交换。
    • for (int k = i * 2 + 1; k < lef; k = k * 2 + 1) 循环遍历当前节点的子节点。
    • if (k + 1 < lef && arr[k] < arr[k + 1]) 检查是否存在右子节点,并且右子节点的值是否小于左子节点的值。如果是,那么 k 指向右子节点。
    • if (arr[k] > temp) 如果子节点的值大于父节点的值,交换它们,并继续向下调整。
    • else { break; } 如果子节点的值不大于父节点的值,调整结束。
  5. void swap(int a, int b) 函数用于交换数组中的两个元素。

  6. void heapsort() 函数实现了堆排序算法。

    • for (int i = n / 2 - 1; i >= 0; i--) 从最后一个非叶子节点开始,向前遍历,构建大顶堆。
    • for (int j = n - 1; j > 0; j--) 从最后一个元素开始,向前遍历,进行排序。
      • swap(0, j); 将堆顶元素(最大值)与数组末尾元素交换。
      • adjustHeap(0, j); 调整堆,确保交换后的数组仍然满足大顶堆的性质。
  7. int main() 是程序的入口点。

    • heapsort(); 调用堆排序函数。
    • for (i = 0; i < n; i++) 遍历排序后的数组,并打印每个元素。
    • printf(" "); 在每个元素后面打印一个空格,以便在输出中分隔元素。

这段代码的输出将是数组 arr 中的元素按升序排列的结果。例如,如果 arr 的初始值是 {12, 4, 132, 55, 46, 232, 789, 1, 0, 98, 523, 666},那么输出将是 {0 1 4 12 46 55 98 132 523 666 789}

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

int arr[] = { 12,4,132,55,46,232,789,1,0,98,523,666 };
int n = sizeof(arr) / sizeof(arr[0]);
void adjustHeap(int i, int lef) {
	int temp = arr[i];
	for (int k = i * 2 + 1; k < lef; k = k * 2 + 1) {
		if (k + 1 < lef && arr[k] < arr[k + 1]) {
			k++;
		}
		if (arr[k] > temp) {
			arr[i] = arr[k];
			i = k;
		}
		else {
			break;
		}
	}
	arr[i] = temp;
}

void swap(int a, int b) {
	int temp = arr[a];
	arr[a] = arr[b];
	arr[b] = temp;
}

void heapsort() {
	//构建大顶堆
	for (int i = n / 2 - 1; i >= 0; i--) {
		adjustHeap(i, n);
	}
	//调整堆结构+交换堆顶元素与末尾元素
	for (int j = n - 1; j > 0; j--) {
		swap(0, j);
		adjustHeap(0, j);
	}
}

int main() {
	int i;
	heapsort();
	for (i = 0; i < n; i++) {
		printf("%d", arr[i]);
		printf(" ");
	}
	return 0;
}
相关推荐
云深处@30 分钟前
【数据结构】树&&堆
数据结构
我命由我1234544 分钟前
Visual Studio - Visual Studio 修改项目的字符集
c语言·开发语言·c++·ide·学习·visualstudio·visual studio
星火开发设计1 小时前
关联式容器:map 与 multimap 的键值对存储
java·开发语言·数据结构·c++·算法
散峰而望1 小时前
【算法竞赛】二叉树
开发语言·数据结构·c++·算法·深度优先·动态规划·宽度优先
Stringzhua1 小时前
队列-双端队列【Queue2】
java·数据结构·算法·队列
重生之后端学习2 小时前
994. 腐烂的橘子
java·开发语言·数据结构·后端·算法·深度优先
硬汉嵌入式2 小时前
斯坦福大学计算机科学早期发布的简明C语言教程《Essential C》
c语言·开发语言
聆风吟º2 小时前
【C标准库】理解C语言中的abs函数:计算整数的绝对值
c语言·abs·库函数·绝对值
jyhappy1232 小时前
深入理解 STM32 的 GPIO — 从零开始点亮第一颗 LED
c语言·stm32·单片机·嵌入式硬件·mcu
m0_531237172 小时前
C语言-if/else,switch/case
c语言·数据结构·算法