堆排序-TOP-K问题(C语言数据结构)

2024-08-27 06:04

本文主要是介绍堆排序-TOP-K问题(C语言数据结构),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:

        学习堆及堆排序,认识到堆的内部原理,这时候就应该运用在实体场景。

        例如:全校有2000人,如何帅选出成绩最好的前10名。

                   帅选出全球前100所最具潜力的公司等等。

TOP-K问题:

如何创造出多个数据?

        在32位机器上整型占4个字节,电脑一般自带内存是8GB或者16GB,也就是最多存储

2,147,483,648个整型数据。

        如果一次性的数量比较大超过了21亿,此时就需要将数据存储在硬盘上面,通常硬盘的内存会比较大,当我们需要的时候在硬盘上去读取数据即可。

将数据写入文件中:

        这里涉及到如何将数据写入文件中,也就是文件相关的操作:文件操作(1)(C语言版)-CSDN博客

        可以根据以前写的文章进行复习。

在这里我们将数据写入文件中用fprintf,读取时用fscanf。(运用格式化读写会比较方便!)

将文件打开并将数据写入:

void CreatData()
{srand((unsigned int)time(NULL));char name[] = { "data.txt" };int arr[100000];int a = 0;FILE* data = fopen(name, "w");if (data == NULL){perror("fopen ::error");exit(-1);}for (int i = 0; i < 100000; i++){a = (rand() + i) % 10000;arr[i] = a;}for (int i = 0; i < 100000; i++){fprintf(data,"%d\n",arr[i]);}fclose(data);
}

TOP-K思路:

        因为小堆的最上层是最小的,如果没有比堆里面最小的大,那么就是最大的10个

主要思路还是“沉底思想”

代码:

void AdjustUp(HPDataType* a, int child)
{int parent = (child - 1) / 2;while (child > 0){if (a[child] < a[parent]){swap(&a[child], &a[parent]);child = parent;parent = (child - 1) / 2;}else{break;}}
}
void AdjustDown(HPDataType* a, int size, int parent)
{//假设最大的孩子的值是左孩子对应的数值int childmax = (parent * 2) + 1;while (childmax < size){//如果右有孩子并且右孩子的值是大于左孩子将最大的孩子换成右孩子if (childmax + 1 < size && a[childmax + 1] < a[childmax]){childmax = childmax + 1;}if (a[parent] > a[childmax]){swap(&a[parent], &a[childmax]);parent = childmax;childmax = (parent * 2) + 1;}else{break;}}
}
void swap(HPDataType* a, HPDataType* b)
{HPDataType c = 0;c = *a;*a = *b;*b = c;
}
void CreatData()
{srand((unsigned int)time(NULL));char name[] = { "data.txt" };int arr[100000];int a = 0;FILE* data = fopen(name, "w");if (data == NULL){perror("fopen ::error");exit(-1);}for (int i = 0; i < 100000; i++){a = (rand() + i) % 10000;arr[i] = a;}for (int i = 0; i < 100000; i++){fprintf(data,"%d\n",arr[i]);}fclose(data);
}
void test3()
{//创造数据CreatData();FILE* data = fopen("data.txt", "r");if (data == NULL){perror("fopen :error");exit(-1);}int k = 10;//创建堆int* heap = (int*)malloc(sizeof(int) * k);if (heap == NULL){perror("heap::error");exit(-1);}//建立k个数的小堆for (int i = 0; i < k; i++){fscanf(data,"%d",&heap[i]);AdjustUp(heap,i);}//比较所有的数,如果有大于堆顶的将覆盖,并向下调整int a = 0;while (fscanf(data,"%d",&a) != EOF){if (heap[0] < a){heap[0] = a;AdjustDown(heap, k, 0);}}for (int i = 0; i < k; i++){printf("%d ", heap[i]);}free(heap);heap = NULL;fclose(data);
}

这篇关于堆排序-TOP-K问题(C语言数据结构)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1110839

相关文章

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

MySQ中出现幻读问题的解决过程

《MySQ中出现幻读问题的解决过程》文章解析MySQLInnoDB通过MVCC与间隙锁机制在可重复读隔离级别下解决幻读,确保事务一致性,同时指出性能影响及乐观锁等替代方案,帮助开发者优化数据库应用... 目录一、幻读的准确定义与核心特征幻读 vs 不可重复读二、mysql隔离级别深度解析各隔离级别的实现差异