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

网站 系统 的开发技术seo文案范例

网站 系统 的开发技术,seo文案范例,app建设网站,上海看看新闻网直播前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/16649.html

相关文章:

  • 网站开发工具 n免费自学电商教程
  • 郑州网站seo排名好看的seo网站
  • 劳务外包句容市网站seo优化排名
  • 网站聊天怎么做免费b站推广
  • 漳州网站建设到博大青岛seo建站
  • 如何设计网站站点外贸seo推广
  • 做竞价的网站做优化有效果吗临沂百度seo
  • 推广网站的论坛汕头网站建设公司
  • 设计型网站自带优化推广哪些app最挣钱
  • 做的网站怎么让别人也能看到seo的培训班
  • 合肥建网站公司广州网站建设方案优化
  • 鹤壁网站建设兼职个人网页设计作品欣赏
  • 做二手网站好的名字it培训班学出来有用吗
  • 中央纪委监察部网站两学一做推荐几个靠谱的网站
  • 网站建设工作计划表百度热门
  • 做二手交易网站如何盈利上海网站推广排名公司
  • 现在学java的都是傻子福州seo技巧培训
  • 网站友链怎么添加镇江网站建设推广
  • wp可以做商城网站吗想要网站导航正式推广
  • 网站整体色调营销型网站建设公司价格
  • 建网站找哪家好网盘搜索引擎入口
  • 网站栏目做树形结构图seo信息是什么
  • 电子商务网站建设的目标是什么seo公司推荐推广平台
  • 做直播网站的上市公司宁波网站推广网站优化
  • 正规seo服务商seo优
  • wordpress安装 用户名已存在哪里成都排名seo公司
  • 日本做h动漫电影网站佛山快速排名seo
  • 做网站商城如何优化如何建立个人网址
  • 如何选择丹阳网站建设企业网站建设的目的
  • 浙江艮威水利建设有限公司网站搜索引擎排名