当前位置: 首页 > news >正文

cnzz网站代做手机如何制作网站教程

cnzz网站代做,手机如何制作网站教程,wordpress落地页,长沙购物网站建设目录 1.解题思路2.创建一个文件并在文件中写入数据3.为什么要建立小堆而不建立大堆?4.如何在现有的数据中建立适合的大堆?5.代码实现 1.解题思路 TopK问题即是在众多数据中找出前K大的值,则可以根据堆的性质来实现,但在使用堆之前…

目录

  • 1.解题思路
  • 2.创建一个文件并在文件中写入数据
  • 3.为什么要建立小堆而不建立大堆?
  • 4.如何在现有的数据中建立适合的大堆?
  • 5.代码实现

1.解题思路

TopK问题即是在众多数据中找出前K大的值,则可以根据堆的性质来实现,但在使用堆之前,我们要想办法先去建立一个堆,那么建立大堆还是小堆?答案是建立小堆.

2.创建一个文件并在文件中写入数据


void CreateNDate()
{// 造数据int n = 10000;srand(time(0));const char* file = "data.txt";FILE* fin = fopen(file, "w");if (fin == NULL){perror("fopen error");return;}for (size_t i = 0; i < n; ++i){int x = rand() % 1000000;fprintf(fin, "%d\n", x);}fclose(fin);
}

3.为什么要建立小堆而不建立大堆?

假设数据的范围是1到100,如果要求找出前10大的值,如果我们建立大堆,假设第一个值正好是最大的,那么这个堆里就不会在进入其他的值了,这明显是错误的.
在这里插入图片描述

但如果建立小堆,每个元素在插入的时候与堆首元素进行比较,如果比首元素大那就替换并向下调整,这样一来,就可以实现我们想要的结果.

4.如何在现有的数据中建立适合的大堆?

我们可以根据K的不同,建立不同大小的堆,加入要找前K个值,那么我们就建立大小为K的小堆,建堆又有两种方式,即向上调整法和向下调整法,在之前的文章中我证明了向上调整法的时间复杂度是O(N*logN)而向下调整法的时间复杂度是O(N),因此如果追求时间复杂的的话,向下调整法会更好


for (int i = (k-2)/2; i < k; i++)
{AdjustDown(topK, k, i);}
/*for (int i = k - 1; i > 0; i--)
{AdjustUp(topK, i);
}*/

5.代码实现

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<time.h>
void Swap(int* p1, int* p2)
{int tmp = *p1;*p1 = *p2;*p2 = tmp;}
void AdjustDown(int* a, int n, int parent)
{int child = parent * 2 + 1;while (child < n){if (child+1<n&&a[child + 1] < a[child]){child++;}if (a[parent] > a[child]){Swap(&a[parent], &a[child]);}parent = child;child = parent * 2 + 1;}}
void AdjustUp(int* a, int child)
{int parent = (child - 1) / 2;while (child > 0){if (a[parent] > a[child]){Swap(&a[parent], &a[child]);}child = parent;parent = (child - 1) / 2;}}void CreateNDate()
{// 造数据int n = 10000;srand(time(0));const char* file = "data.txt";FILE* fin = fopen(file, "w");if (fin == NULL){perror("fopen error");return;}for (size_t i = 0; i < n; ++i){int x = rand() % 1000000;fprintf(fin, "%d\n", x);}fclose(fin);
}
void PrintTopK(const char* file,int k)
{int* topK = (int*)malloc(sizeof(int) * k);assert(topK);FILE* fout = fopen(file, "r");//读取文件 fileif (fout == NULL) {perror("open fail");return;}for (int i = 0; i < k; i++) {fscanf(fout, "%d", &topK[i]);}for (int i = (k-2)/2; i < k; i++){AdjustDown(topK, k, i);}/*for (int i = k - 1; i > 0; i--){AdjustUp(topK, i);}*/int val = 0;int ret= fscanf(fout, "%d", &val);while (ret != EOF){if (val > topK[0]){topK[0] = val;AdjustDown(topK, k, 0);}ret = fscanf(fout, "%d", &val);}for (int i = 0; i < k; i++){printf("%d ", topK[i]);}fclose(fout);}
int main()
{CreateNDate();PrintTopK("data.txt", 10);return 0;}

实际上,我们可以看出,虽然建堆的时间复杂度可以优化,但是后面的从文件中读取数据并进行判断是否替换的过程是无法进行优化的时间复杂度为O(N*logN),因此建堆的时间复杂度并不影响整个算法的时间复杂度

结尾:今天的分享到此结束,喜欢的朋友如果感觉有帮助可以点赞三连支持,咱们共同进步!

http://www.mmbaike.com/news/53511.html

相关文章:

  • cad效果图怎么制作济南百度推广优化
  • 交互式网站开发技术有哪些中国今天刚刚发生的新闻
  • 中国做网站最好的公司seo网站推广助理
  • 公安机关网站规范化建设应用网络营销策划书的结构是什么
  • 用python做网站的步骤绍兴seo推广
  • 东莞网站设计方案注册城乡规划师报考条件
  • 公司起名生成器惠州seo关键字排名
  • 模板网站制作公司百度云搜索引擎 百度网盘
  • 怎么做自己的免费网站中南建设集团有限公司
  • 中国十大建筑设计事务所宁波seo行者seo09
  • 南通网站建设知识手机百度旧版本下载
  • 域名网站空间在线crm管理系统
  • 苹果给第三方网站做图标微信公众号推广网站
  • 政府门户网站建设情况工作汇报广州seo网络培训课程
  • 鸿星尔克品牌策划方案seo优化排名
  • 中山网站建设文化平台百度一下首页网页
  • 做网站用什么web服务器吗百度网址浏览大全
  • 网站怎么做域名实名认证网络服务包括
  • 网页游戏大全双人广州seo网络营销培训
  • 做阿里巴巴跟网站哪个更好做公司网站
  • 凡科网做的网站保存后就上传了吗高清视频网络服务器
  • cdr做网站分辨率制作网页的软件有哪些
  • 网站换网址了怎么找seo搜索引擎入门教程
  • 郑州做网站推广电话今日新闻头条大事
  • 微网站上的一键导航怎么做企业文化的重要性和意义
  • 如何进行网站网站调试百度一下网页打开
  • 用邮箱做网站谷歌seo网站排名优化
  • 怎么注销网站备案免费b站推广网站详情
  • 惠州做网站公司哪家好合肥网站seo公司
  • led灯具网站模板成都网站维护