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

做移动网站优化软件discuz论坛seo设置

做移动网站优化软件,discuz论坛seo设置,做企业网站好的,wordpress主题 github一、堆的定义 二、堆(优先队列) 堆通常用于实现优先队列(priority_queue),大顶堆相当于元素按从大到小的顺序出队的优先队列。从使用角度来看,我们可以将“优先队列”和“堆”看作等价的数据结构。 堆的…

一、堆的定义

二、堆(优先队列)

堆通常用于实现优先队列(priority_queue),大顶堆相当于元素按从大到小的顺序出队的优先队列。从使用角度来看,我们可以将“优先队列”和“堆”看作等价的数据结构。

堆的常见用法:

/* 初始化堆 */
// 初始化小顶堆
priority_queue<int, vector<int>, greater<int>> minHeap;
// 初始化大顶堆
priority_queue<int, vector<int>, less<int>> maxHeap;/* 元素入堆 */
maxHeap.push(1);
maxHeap.push(3);
maxHeap.push(2);
maxHeap.push(5);
maxHeap.push(4);/* 获取堆顶元素 */
int peek = maxHeap.top(); // 5/* 堆顶元素出堆 */
// 出堆元素会形成一个从大到小的序列
maxHeap.pop(); // 5
maxHeap.pop(); // 4
maxHeap.pop(); // 3
maxHeap.pop(); // 2
maxHeap.pop(); // 1/* 获取堆大小 */
int size = maxHeap.size();/* 判断堆是否为空 */
bool isEmpty = maxHeap.empty();/* 输入列表并建堆 */
vector<int> input{1, 3, 2, 5, 4};
priority_queue<int, vector<int>, greater<int>> minHeap(input.begin(), input.end());

三、堆的常见应用

  • 优先队列:堆通常作为实现优先队列的首选数据结构,其入队和出队操作的时间复杂度均为 0(log⁡n) ,而建队操作为 0(n),这些操作都非常高效。
  • 堆排序:给定一组数据,我们可以用它们建立一个堆,然后不断地执行元素出堆操作,从而得到有序数据。
  • 获取最大的 K 个元素:这是一个经典的算法问题,同时也是一种典型应用,例如选择热度前 10 的新闻作为微博热搜,选取销量前 10 的商品等。

四、具体思路top-k问题:

  1. 初始化一个小顶堆,其堆顶元素最小。
  2. 先将数组的前 k 个元素依次入堆。
  3. 从第 k+1 个元素开始,若当前元素大于堆顶元素,则将堆顶元素出堆,并将当前元素入堆。
  4. 遍历完成后,堆中保存的就是最大的 k个元素。
/* 基于堆查找数组中最大的 k 个元素 */
priority_queue<int, vector<int>, greater<int>> topKHeap(vector<int> &nums, int k) {// 初始化小顶堆priority_queue<int, vector<int>, greater<int>> heap;// 将数组的前 k 个元素入堆for (int i = 0; i < k; i++) {heap.push(nums[i]);}// 从第 k+1 个元素开始,保持堆的长度为 kfor (int i = k; i < nums.size(); i++) {// 若当前元素大于堆顶元素,则将堆顶元素出堆、当前元素入堆if (nums[i] > heap.top()) {heap.pop();heap.push(nums[i]);}}return heap;
}

总共执行了 n 轮入堆和出堆,堆的最大长度为 k ,因此时间复杂度为 0(nlogk)。该方法的效率很高,当 k 较小时,时间复杂度趋向0(n) ;当k 较大时,时间复杂度不会超过 0(nlog⁡n) 。

另外,该方法适用于动态数据流的使用场景。在不断加入数据时,我们可以持续维护堆内的元素,从而实现最大的 k个元素的动态更新

五、习题:

215. 数组中的第K个最大元素

class Solution {
public:int findKthLargest(vector<int>& nums, int k) {//建大顶堆priority_queue<int,vector<int>,greater<int>>heap;int n=nums.size();for(int i=0;i<k;i++){heap.push(nums[i]);}for(int i=k;i<n;i++){if(nums[i]>heap.top()){heap.pop();heap.push(nums[i]);}   }return heap.top();}
};

264. 丑数 II

给你一个整数 n ,请你找出并返回第 n 个 丑数 。

丑数 就是质因子只包含 23 和 5 的正整数。

思路:如果x是丑数,则2x、3x、5x也是丑数。所以我们不妨使用一个优先队列,存储这些丑数。

每次取出堆顶元素 x,则 x 是堆中最小的丑数,由于 2x,3x,5x 也是丑数,因此将 2x,3x,5x加入堆。

上述做法会导致堆中出现重复元素的情况。为了避免重复元素,可以使用哈希集合去重,避免相同元素多次加入堆。

哈希去重:

unordered_set<long> seen;//建立哈希表
//seen.count(x)//对x元素计数。if(!seen.count(x))//x此时一个都没有
seen.insert(x);//插入到哈希表中,此时数量就为一了
class Solution {
public:int nthUglyNumber(int n) {//哈希表去重unordered_set<long> seen;vector<int>factors={2,3,5};priority_queue<long,vector<long>,greater<long>>heap;seen.insert(1L);heap.push(1L);int ugly=0;for(int i=0;i<n;i++){long curr=heap.top();heap.pop();ugly=(int)curr;for(int factor:factors){long next=curr*factor;if(!seen.count(next)){seen.insert(next);heap.push(next);}}}return ugly;}
};

另外一个方法:. - 力扣(LeetCode)

http://www.hotlads.com/news/3250.html

相关文章:

  • 淘宝购物券网站怎么做夫唯老师seo
  • 大淘客网站怎么做湖北网站建设制作
  • 网站后台账号密码破解seo 优化
  • 长沙企业模板建站上海推广seo
  • 网站开发申请微信支付大数据推广公司
  • 东丽天津网站建设广州推广系统
  • 阿里云免费网站建设百度网址收录入口
  • 上海网站推广服务公司青岛seo排名扣费
  • 网站建设资金筹措的方案竞价专员是做什么的
  • 白酒网站模板中小企业网站制作
  • 免费织梦网站源码下载怎样创建自己的网站
  • 济宁公司做网站谷歌排名网站优化
  • 徐州高端模板建站山东网站seo
  • 苏州网站建设找哪家线上广告
  • 网页设计网站多少钱百度一下百度搜索百度一下
  • 成都创新互联网站建设真正永久免费的建站系统有哪些
  • asp网站安全怎么做天津关键词优化网排名
  • 网站备案查询系统php版怎样制作属于自己的网站
  • 如何360收录网站优化营商环境工作总结
  • 深圳知名网站建设网店运营教学
  • 百度做网站刷排名搜索引擎seo优化平台
  • 做新媒体每天必看的网站河南制作网站公司
  • 企业官方网站格式seo排名优化教程
  • 上海招聘网站建设百度售后电话人工服务
  • qq开放平台网站开发申请不通过的原因岳阳seo
  • 福建建站公司网站免费建站app
  • 进什么网站接模具做网站推广途径和要点
  • 广东网站建设公司seo引擎搜索网站
  • 建立网站需要多少钱八寇湖南岚鸿团队搜索引擎营销的常见方式
  • 赤城县城乡建设局网站深圳网站建设公司