c-数据结构:堆排序代码实现及测试(大根堆)

1 前言:

本文章不包含堆排序原理,只介绍实现和代码测试部分。原理内容读者需自行查阅相关资料

2 完整代码

/*
* Author: @utah
* Date:   2023-12-9
* Subject:堆排序
*/

#define _CRT_SECURE_NO_WARNINGS 1

#include<stdio.h>
#include<string.h>

// 1 大根堆的调整 (下标k为根)
// void headAdjust(原始数组,根下标,数组长度)
void HeadAdjust(int a[],int k,int len) {
	// 保存根节点的值 0号位置用作中转点,排序后的数据从1号位置开始
	a[0] = a[k];

	// 调整为大根堆 2k为左孩子,2k+1为右孩子
	for (int i = 2 * k; i <= len; i *= 2) {
		if (a[i] < a[i + 1] && i < len) {
			i++;
		}

		if (a[0] >= a[i]) {
			break;
		}
		else {
			a[k] = a[i];
			k = i;
		}
	}
	a[k] = a[0];
 }

// 建立大根堆(基于大根堆调整函数)
void CreatMaxHeap(int a[], int len) {
	for (int i = (len / 2); i > 0; i--) { // 只需要处理非终端节点
		HeadAdjust(a, i, len);
	}
}

// 堆排序代码
void HeapSort(int a[], int len) {
	CreatMaxHeap(a, len);
	for (int i = len-1; i > 1; i--) {
		swap(&a[i], &a[1]);
		HeadAdjust(a, 1, i - 1);
	}
}

// 2个辅助函数
void printArr(int a[], int len) {
	for (int i = 1; i < len; i++) {
		printf("%d ", a[i]);
	}
}

void swap(int* a, int* b) {
	int temp = *a;
	*a = *b;
	*b = temp;
}
// 主函数
int main()
{
	int a[10] = { 8,5,7,4,3,6,2,9,1,10 };
	int len = 10;

	HeapSort(a, len);
	printArr(a,len);

	return 0;
}

 

3 堆排序算法分析

1 时间复杂度 O(nlog2(n)) 建堆时间O(n)
2 空间复杂度 O(1)
3 稳定性 不稳定

By the way

代码部分在vs2023社区版下测试完成,未发现错误,如果读者发现错误,务必留言联系作者。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值