堆排序-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

相关文章

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1

SpringBoot内嵌Tomcat临时目录问题及解决

《SpringBoot内嵌Tomcat临时目录问题及解决》:本文主要介绍SpringBoot内嵌Tomcat临时目录问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录SprinjavascriptgBoot内嵌Tomcat临时目录问题1.背景2.方案3.代码中配置t

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带

resultMap如何处理复杂映射问题

《resultMap如何处理复杂映射问题》:本文主要介绍resultMap如何处理复杂映射问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录resultMap复杂映射问题Ⅰ 多对一查询:学生——老师Ⅱ 一对多查询:老师——学生总结resultMap复杂映射问题