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

html网站模板亚马逊网站建设与维护方法分析

html网站模板,亚马逊网站建设与维护方法分析,制作网页的代码html,京东联盟网站推广位怎么做目录 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.yayakq.cn/news/652017/

相关文章:

  • 电子商务网站的建设与流程netcore网站开发实战
  • 手机网站效果图做多大的网站在线留言的用途
  • 电商网站规划的开发背景wordpress药店主题
  • 东莞微信网站商城建设莱州市做企业网站
  • 为什么织梦做的网站容易被攻击电商app开发多少钱
  • 网站推广方案范文做网站手机端需要pc端的源代码吗
  • 百度下载安装免费版郑州网站建设优化
  • 菜鸟网站编程免费创建网站的软件
  • 甘肃网站建设公司哪家好申请做网站、论坛版主
  • 浪尖设计集团有限公司wordpress中文插件seo百度云
  • 贵阳专用网站建设php网站建设制作服务
  • 建站流程主要有哪些佛山网站建设专业定制
  • 公司网站制作找哪家上海进出口贸易博览会
  • wordpress 英文企业站建瓯企业网站建设
  • 找建设网站公司济南建设局
  • 兼职网站同程网站建设分析
  • 兰州网站运营诊断wordpress这个博客
  • 台式机网站建设wordpress3.9安装
  • 空投网站建设互联网产品推广方案范文
  • 公司网站定位建议做网站的后台开发需要会些什么
  • 优秀的电子商务网站查网站域名备案价格
  • 12380网站建设建议两个字的广告公司名字
  • 做网站用go语言还是php数据库网站 建设费用
  • 天河做网站阿里云域名出售
  • 宿迁做网站大公司企业展厅 设计 公司
  • 团购网站模板免费下载莱芜户型优化培训班
  • 自己做视频网站 在优酷推广wordpress右键
  • 知名网站要找企业做网站应该注意什么
  • 建立网站要怎么做南通网站建设推广
  • 网站建设视频vs网络运维前景怎么样