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

免费网站生成软件十大免费引流平台

免费网站生成软件,十大免费引流平台,昆山品牌设计公司,湖北潜江信息网前K个高频单词一、题目链接二、题目三、分析四、代码一、题目链接 692.前K个高频单词 二、题目 三、分析 本题目我们利用map统计出次数以后,返回的答案应该按单词出现频率由高到低排序,有一个特殊要求,如果不同的单词有相同出现频率&#…

前K个高频单词

  • 一、题目链接
  • 二、题目
  • 三、分析
  • 四、代码

一、题目链接

692.前K个高频单词

二、题目

在这里插入图片描述

三、分析

本题目我们利用map统计出次数以后,返回的答案应该按单词出现频率由高到低排序,有一个特殊要求,如果不同的单词有相同出现频率,按字典顺序排序。

解法一:用排序找前k个单词,因为map中已经对key单词排序过,也就意味着遍历map时,次数相同的单词,字典序小的在前面,字典序大的在后面。那么我们将数据放到vector中用一个稳定的排序就可以实现上面特殊要求,但是sort底层是快排,是不稳定的,所以我们要用stable_sort,他是稳定的。

涉及到排序的稳定性,稳定性好的排序是:冒泡、插入、归并,保证相等的值的相对顺序不变。

算法库里有一个稳定的排序(底层是归并,用其他的稳定的排序效率太低):

在这里插入图片描述

解法二:不用stable_sort有什么办法解决呢?将map统计出的次数的数据放到vector中排序,或者放到priority_queue中来选出前k个。利用仿函数强行控制次数相等的,字典序小的在前面。

四、代码

解法一:

class Solution {
public:// stable_sort与库里的pair比较行为不符,自定义比较器——定制仿函数struct Compare{bool operator()(const pair<string, int>& kv1, const pair<string, int>& kv2){return kv1.second > kv2.second;}};vector<string> topKFrequent(vector<string>& words, int k) {// 次数map<string, int> countMap;for (auto& e : words){countMap[e]++;}// 排降序 —— map的数据倒过来,字典序排过了vector<pair<string, int>> v(countMap.begin(), countMap.end());// 仿函数控制降序stable_sort(v.begin(), v.end(), Compare());/* LeetCode平台支持打印 *///for (auto& e : v)//{//    cout << e.first << ":" << e.second << endl;//}vector<string> ret;for (int i = 0; i < k; ++i){ret.push_back(v[i].first);}return ret;}
};

解法二:

class Solution {
public:// stable_sort与库里的pair比较行为不符,自定义比较器——定制仿函数struct Compare{bool operator()(const pair<string, int>& kv1, const pair<string, int>& kv2){return kv1.second > kv2.second || (kv1.second == kv2.second && kv1.first < kv2.first);}};vector<string> topKFrequent(vector<string>& words, int k) {// 次数map<string, int> countMap;for (auto& e : words){countMap[e]++;}// 排降序vector<pair<string, int>> v(countMap.begin(), countMap.end());// 仿函数控制降序,仿函数控制次数相等,字典序小的在前面sort(v.begin(), v.end(), Compare());// 取前k个vector<string> ret;for (int i = 0; i < k; ++i){ret.push_back(v[i].first);}return ret;}
};
class Solution {
public:// stable_sort与库里的pair比较行为不符,自定义比较器——定制仿函数struct Compare{bool operator()(const pair<string, int>& kv1, const pair<string, int>& kv2){// 要注意优先级队列底层是反的,大堆要实现小于比较,所以这里次数相等,想要字典序小的在前面要比较字典序大的为真return kv1.second < kv2.second || (kv1.second == kv2.second && kv1.first > kv2.first);}};vector<string> topKFrequent(vector<string>& words, int k) {// 次数map<string, int> countMap;for (auto& e : words){countMap[e]++;}// 将map中的<单词,次数>放到priority_queue中,仿函数控制大堆,次数相同按照字典序规则排序priority_queue<pair<string, int>, vector<pair<string, int>>, Compare> p(countMap.begin(), countMap.end());vector<string> ret;for (int i = 0; i < k; i++){ret.push_back(p.top().first);p.pop();}return ret;}
};
http://www.dtcms.com/wzjs/839516.html

相关文章:

  • 松原手机网站开发公司电话logo设计方案
  • 用vs做的网站怎么打开网站优化培训班
  • jsp网站建设项目实战电子版代理平台登录
  • 网络彩票代理怎么做社区网站微信怎么做一个小程序
  • seo的基础优化深圳网站搜索优化工具
  • 怎么做网站程序wordpress 企业建站
  • 网站设计不需要考虑关于asp.net的网站模板
  • 网站开发客户端网站建设响应式是什么
  • 做网站赚钱的案例网站职业技能培训有哪些项目
  • 网店设计模板WordPress速度优化2019
  • 男男做视频网站网站设计的标准
  • 龙岗区做网站网站开发文档源码
  • 网站设计在线培训普通网站建设多少钱
  • 丽水企业网站开发企业网站添加背影音乐怎么做
  • 达建网站防止爬虫的办法成品直播app源码
  • 需要锦州网站建设珠海华兴建设工程有限公司网站
  • 宁阳网站设计网站找建站公司
  • 内蒙古建设协会网站广州网站建设讯度
  • 青岛网站设计制作福田网站建设哪家好
  • 有经验的合肥网站建设企业网站推广名词解释
  • 新网站怎么做谷歌推广呢用什么做响应式网站
  • 昌吉州建设局网站安卓开发简单网站开发代码下载
  • 大连做网站 智域制作网站的费用
  • 做的最好的理财网站wordpress和worldpress
  • 无锡做网站f7wl网站的域名空间
  • 宏润建设集团股份有限公司网站html5 公司网站
  • 济南网站建设那家好外贸网站
  • 教学网站开发应用方案暗红色网站
  • 风景网站模板网站开发安全
  • 培训行业门户网站建设方案最简单的安卓开发工具