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

做国外贸易的网站seo权重优化

做国外贸易的网站,seo权重优化,江西网站建设哪家公司好,自己做的网站竞价优化我们有一个长度为 M 的数组,现在我们想从中找出 最小的 N 个元素。例如: int a[10] {12, 3, 5, 7, 19, 0, 8, 2, 4, 10};从中找出 最小的 4 个元素。 正确方法:使用大小为 N 的「大顶堆」 原因分析: 我们想保留最小的 4 个元素…

我们有一个长度为 M 的数组,现在我们想从中找出 最小的 N 个元素。例如:

int a[10] = {12, 3, 5, 7, 19, 0, 8, 2, 4, 10};

从中找出 最小的 4 个元素


正确方法:使用大小为 N 的「大顶堆」

原因分析:

我们想保留最小的 4 个元素,因此可以使用一个大顶堆,堆的作用是“维护最小的 N 个数”。

思路如下:

  1. 初始化:先把前 4 个数放入堆中 → 12, 3, 5, 7
    • 堆顶为最大值 12,表示目前“最小的 4 个元素”中最大的那个是 12。
  2. 从第 5 个数开始往后遍历数组,只要当前数 < 堆顶,就替换堆顶
  3. 最终堆中留下的是“最小的 4 个数”。

具体步骤(维护一个大顶堆):

初始数组:

{12, 3, 5, 7, 19, 0, 8, 2, 4, 10}

步骤:

  • 初始化堆(大顶堆):[12, 3, 5, 7] → 堆顶是 12
  • 接下来遍历:
当前元素与堆顶比较操作新堆内容(无序表示)
19> 12略过[12, 3, 5, 7]
0< 12删除 12,插入 0[7, 3, 5, 0]
8> 7略过[7, 3, 5, 0]
2< 7删除 7,插入 2[5, 3, 2, 0]
4< 5删除 5,插入 4[4, 3, 2, 0]
10> 4略过[4, 3, 2, 0]

最终堆中元素:[0, 2, 3, 4]


如果用小顶堆会怎么样?

假如你误用了小顶堆,初始堆是 [3, 12, 5, 7],堆顶是 3。

你遍历后面的元素时,堆顶一直是最小的那个,永远不会被替换掉。

问题是:你不知道当前 4 个是不是最小的 4 个,因为最大值还留在里面!

你得存下所有 M 个元素,再从小顶堆中取前 N 个,等于多维护了不必要的 M - N 个元素,效率大大降低。


总结口诀:

🔹 找最小的 N 个数 → 用大小为 N 的大顶堆,因为你要踢走大的。
🔹 找最大的 N 个数 → 用大小为 N 的小顶堆,因为你要踢走小的。


http://www.dtcms.com/wzjs/461619.html

相关文章:

  • 推广联盟网站怎么做seo排名软件价格
  • 哪家做网站性价比高dw网页制作详细步骤
  • 网站建设找汉狮营销方案怎么写模板
  • 资讯类网站怎么做营销渠道模式有哪些
  • 网站怎么做图片动态图片不显示了seo前景
  • 汉口网站建设制作自己手机怎么免费做网站
  • 网站 开发 合同广东广州疫情最新情况
  • wordpress增加登录账户优化加速
  • 网站策划编辑是干嘛的北京软件培训机构前十名
  • 门户网站建设标准简述获得友情链接的途径
  • 湖北做网站网址导航下载到桌面
  • html中秋节网页制作代码长沙百度网站推广优化
  • 公司网站的定义谷歌搜索官网
  • 检测网站是否被做跳转seo怎么学在哪里学
  • 网站手机版怎么弄app开发需要多少钱
  • pc建站网站重庆二级站seo整站优化排名
  • 营销网站结构网店营销策划方案范文
  • Wordpress建站安装教程图解网址收录查询
  • 小公司做网站免费发布广告的网站
  • 农村建设自己的网站站长工具同大全站
  • 网站制作.com语言教育培训机构排名前十
  • 网站建设 网络推广 网站优化百度快速排名工具
  • 哪里长沙网站开发seo属于什么
  • 娱乐网站设计多少行业站外seo推广
  • 专业购物网站建设可以免费发广告的网站
  • 为什么做网站要用谷歌浏览器做百度推广怎么做才能有电话
  • 离石做网站的网络公司上海牛巨仁seo
  • 论坛源码推荐网站推广和优化的原因
  • 软件开发专业适合女生吗seo外包公司哪家好
  • b2c商城网站开发福州seo结算