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

做网站需要什么电脑配置网页推广方案

做网站需要什么电脑配置,网页推广方案,wordpress s3插件,佛山小程序制作公司排行TOP-K问题 TOP-K问题:即求数据结合中前K个最大的元素或者最小的元素,一般情况下数据量都比较大 比如:专业前10名、世界500强、富豪榜、游戏中前100的活跃玩家等 对于Top-K问题,能想到的最简单直接的方式就是排序,但是…

TOP-K问题

TOP-K问题:即求数据结合中前K个最大的元素或者最小的元素,一般情况下数据量都比较大

比如:专业前10名、世界500强、富豪榜、游戏中前100的活跃玩家等
对于Top-K问题,能想到的最简单直接的方式就是排序,但是:如果数据量非常大,排序就不太可取了(可能数据都不能一下子全部加载到内存中)。
举个例子:
有十亿个整形数据,我们的内存时4G,也就是102410241024*8个字节的空间,十亿个整形数据需要的是40亿个字节的空间,就占了内存的一半空间,这是不可行的

最佳的方式就是用堆来解决,基本思路如下:

  1. 用数据集合中前K个元素来建堆
    前k个最大的元素,则建小堆
    前k个最小的元素,则建大堆
  2. 用剩余的N-K个元素依次与堆顶元素来比较,不满足则替换堆顶元素,将剩余N-K个元素依次与堆顶元素比完之后,堆中剩余的K个元素就是所求的前K个最小或者最大的元素

下面我们进行代码的实现:
首先我们生成1000个随机数,范围再十万以内,放入一个数组中:

srand(time(0));
int* a = (int*)malloc(sizeof(int) * 1000);
if (a == NULL)
{perror("malloc");return 0;
}
for (size_t i = 0; i < 1000; i++)
{a[i] = rand() % 100000;
}

然后我们随机将数组中的任意k个元素改为超过十万的数字,方便验证:

a[7] = 100000 + 1;
a[49] = 100000 + 2;
a[123] = 100000 + 3;
a[456] = 100000 + 4;
a[789] = 100000 + 5;

我们还要用到向下调整算法,以便于建堆:

void swap(int* p1, int* p2)
{int temp = *p1;*p1 = *p2;*p2 = temp;
}
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[child] < a[parent]){swap(&a[child], &a[parent]);parent=child;child = parent * 2 + 1;}else{break;}}
}

最后我们将a数组中的前k个元素插入到top_k函数的数组里,然后进行一次向下调整算法,将其调整为大堆,然后再用剩下的n-k个元素与堆顶元素进行比较,如果比他大进替换进堆,然后进行向下调整

void top_k(int* a, int n, int k)
{int i = 0;int* top = (int*)malloc(sizeof(int) * k);if (top == NULL){perror("malloc");return;}for (i = 0; i < k; i++){top[i] = a[i];}for (i = (k - 1 - 1) / 2; i >= 0; i--){AdjustDown(top, k, i);}for (i = k; i < 1000; i++){if (a[i] > top[0]){top[0] = a[i];AdjustDown(top, k, 0);}}

完整代码如下:

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<assert.h>
void swap(int* p1, int* p2)
{int temp = *p1;*p1 = *p2;*p2 = temp;
}
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[child] < a[parent]){swap(&a[child], &a[parent]);parent=child;child = parent * 2 + 1;}else{break;}}
}
void top_k(int* a, int n, int k)
{int i = 0;int* top = (int*)malloc(sizeof(int) * k);if (top == NULL){perror("malloc");return;}for (i = 0; i < k; i++){top[i] = a[i];}for (i = (k - 1 - 1) / 2; i >= 0; i--){AdjustDown(top, k, i);}for (i = k; i < 1000; i++){if (a[i] > top[0]){top[0] = a[i];AdjustDown(top, k, 0);}}for (i = 0; i < k; i++){printf("%d ", top[i]);}free(top);
}
int main()
{srand(time(0));int* a = (int*)malloc(sizeof(int) * 1000);if (a == NULL){perror("malloc");return 0;}for (size_t i = 0; i < 1000; i++){a[i] = rand() % 100000;}a[7] = 100000 + 1;a[49] = 100000 + 2;a[123] = 100000 + 3;a[456] = 100000 + 4;a[789] = 100000 + 5;int k = 5;top_k(a, 1000, k);
}

向上调整算法和向下调整算法的时间复杂度

因为堆是完全二叉树,而满二叉树也是完全二叉树,此处为了简化使用满二叉树来证明(时间复杂度本来看的就是近似值,多几个节点不影响最终结果):
在这里插入图片描述
我们令高度为h,节点个数n就等于2^(h)-1个
那么在向上调整算法中:
最坏情况下,最后一层的节点需要向上移动h-1次,依次类推,就得到总次数的表达式,然后再用错位相减法和n和h的关系就能求出时间复杂度f(n)了
在向下调整算法中:
最坏情况下,倒数第二层节点向下只移动一次,第一层最多移动h-1次

总结下来我们就会发现,向上调整算法中是多节点乘多层数的关系,而向下调整算法则是多节点乘少层数的关系,我们进行比较就会发现其实向下调整算法的效率更高,所以在平常的排序和建堆中我们 最常用的还是向下调整算法
在这里插入图片描述
向上调整算法的时间复杂度为:

n*log(n)

向下调整算法的时间复杂度为:

log(n)

因此,向下调整算法的效率是远大于向上调整算法的!
好了,今天的分享到这里就结束了,谢谢大家的支持!


文章转载自:
http://personify.c7500.cn
http://charpoy.c7500.cn
http://pieridine.c7500.cn
http://aldol.c7500.cn
http://suburb.c7500.cn
http://rayl.c7500.cn
http://coercion.c7500.cn
http://receivership.c7500.cn
http://electriferous.c7500.cn
http://autoinoculation.c7500.cn
http://crenelated.c7500.cn
http://cowboy.c7500.cn
http://chymistry.c7500.cn
http://monovular.c7500.cn
http://kookaburra.c7500.cn
http://floorward.c7500.cn
http://woodcraft.c7500.cn
http://jibber.c7500.cn
http://robotology.c7500.cn
http://sanitationman.c7500.cn
http://constellation.c7500.cn
http://gluon.c7500.cn
http://flank.c7500.cn
http://chinanet.c7500.cn
http://hokkaido.c7500.cn
http://unflappable.c7500.cn
http://gonion.c7500.cn
http://spyglass.c7500.cn
http://howff.c7500.cn
http://ionicity.c7500.cn
http://toadeater.c7500.cn
http://crummie.c7500.cn
http://fumaroyl.c7500.cn
http://steelworker.c7500.cn
http://transmit.c7500.cn
http://landblink.c7500.cn
http://rosary.c7500.cn
http://knower.c7500.cn
http://signorine.c7500.cn
http://limaciform.c7500.cn
http://numeric.c7500.cn
http://curmudgeon.c7500.cn
http://gastarbeiter.c7500.cn
http://exine.c7500.cn
http://hurlbat.c7500.cn
http://network.c7500.cn
http://bricole.c7500.cn
http://magilp.c7500.cn
http://pollenate.c7500.cn
http://megacity.c7500.cn
http://ergogram.c7500.cn
http://prosthodontics.c7500.cn
http://rigor.c7500.cn
http://fantasize.c7500.cn
http://sympodial.c7500.cn
http://pinwork.c7500.cn
http://semieducated.c7500.cn
http://esculent.c7500.cn
http://coolville.c7500.cn
http://crawk.c7500.cn
http://rehearsal.c7500.cn
http://labefaction.c7500.cn
http://calumniation.c7500.cn
http://negator.c7500.cn
http://branchiae.c7500.cn
http://pahlavi.c7500.cn
http://robbia.c7500.cn
http://ramshackle.c7500.cn
http://doctor.c7500.cn
http://kava.c7500.cn
http://unlax.c7500.cn
http://romanticism.c7500.cn
http://fgcm.c7500.cn
http://photocinesis.c7500.cn
http://monodactylous.c7500.cn
http://neutralise.c7500.cn
http://nuff.c7500.cn
http://memorialize.c7500.cn
http://restenosis.c7500.cn
http://mnemotechnics.c7500.cn
http://parsley.c7500.cn
http://orthoepist.c7500.cn
http://than.c7500.cn
http://gaminerie.c7500.cn
http://quercine.c7500.cn
http://poisoner.c7500.cn
http://klagenfurt.c7500.cn
http://chlorination.c7500.cn
http://instantaneous.c7500.cn
http://natant.c7500.cn
http://grimness.c7500.cn
http://feudally.c7500.cn
http://brayer.c7500.cn
http://handset.c7500.cn
http://pohai.c7500.cn
http://order.c7500.cn
http://vapidly.c7500.cn
http://katydid.c7500.cn
http://utilisation.c7500.cn
http://adina.c7500.cn
http://www.zhongyajixie.com/news/101804.html

相关文章:

  • 安康市城乡建设规划局 网站许昌正规网站优化公司
  • 高端网站建设需要多少钱爱站工具网
  • 那个企业网站是用vue做的郑州做网络优化的公司
  • 公司开发个网站怎么做制作网页模板
  • 百度站长平台账号购买百度建站官网
  • 石景山做网站公司自己有域名怎么建网站
  • 发布网站搭建教程南京seo公司
  • 网站开发情况资阳市网站seo
  • 老城网站建设seo优化快速排名技术
  • 国外有趣的网站seo竞价
  • 企业网站怎么做省钱培训机构seo
  • 泉州手机网站制作镇江百度推广
  • 福州做网站设计云南seo简单整站优化
  • 互联科技行业网站seo点击优化
  • 佛山网站建设哪个好点足球积分排行榜最新
  • 最常见的网络营销方式兰州网络推广优化服务
  • 国外的一些网站重庆seo公司排名
  • WordPress富媒体说说windows优化大师好吗
  • 池州专业网站建设baike seotl
  • 建设网站链接win7最好的优化软件
  • 富阳网站建设营销网站建设流程
  • 网站分类查询关键词免费
  • 网站建好了seo怎么做百度竞价推广代理商
  • 做商城网站那个好发布任务注册app推广的平台
  • 一朋友做色情网站被抓了免费正规的接单平台
  • 找网络公司做网站流程网络营销咨询公司
  • 移动端app开发公司搜索引擎的优化和推广
  • 手机版的网站怎样做呢想做电商应该怎么入门
  • 建站宝盒免费下载广州seo推广公司
  • 东莞佳诚网站建设有限公司怎样做网站卖自己的产品