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

推荐好用的浏览器长沙百度快速排名优化

推荐好用的浏览器,长沙百度快速排名优化,2345网址下载,网站开发跟app开发的差别优先队列哈希集合反向思维(或自定义排序) 模拟,请直接看算法思路: 两个哈希集合S1和S2, S1存正面词汇,S2存负面词汇;一个优先队列pq,pq存{score, id}键值对,即学生分数-学生id。 算法流程: 初…
优先队列+哈希集合+反向思维(或自定义排序)

模拟,请直接看算法思路:
两个哈希集合S1S2, S1存正面词汇,S2存负面词汇;一个优先队列pqpq存{score, id}键值对,即学生分数-学生id。

算法流程:

  1. 初始化S1S2
  2. 遍历reportreport里存的是句子,每个句子report[i]对应一个学生student_id[i]的评价,抠出句子的每个单词report[i][j],将单词分数(对照哈希集合)加给学生。上述流程确定了学生student_id[i]的分数,将学生分数加入优先队列。
  3. 记录前k个学生id,存入答案数组ansans即为所求。

请注意:优先队列默认大根堆,按fisrt成员从大到小排序;在first成员相等时,按照second成员从大到小排序。score是first成员,id是second成员,出现矛盾:当score相同时,题目要求id从小到大排序。解决方法:1. 将score变为负数,或将id变为负数。2. 自定义排序规则(优先队列);本题解将score变为负数,解决了矛盾。

class Solution {
public:vector<int> topStudents(vector<string>& positive_feedback, vector<string>& negative_feedback, vector<string>& report, vector<int>& student_id, int k) {// 哈希集合unordered_set<string> S1, S2;vector<int> ans = vector<int> (k, 0); // 保存答案的ans顺序priority_queue <pair<int, int>, vector<pair<int,int>>> pq; // 存{score, id}键值对。for (int i = 0; i < positive_feedback.size(); i ++) {S1.insert(positive_feedback[i]);}for (int i = 0; i < negative_feedback.size(); i ++) {S2.insert(negative_feedback[i]);}for (int i = 0; i < report.size(); i ++) {int j = 0; // 遍历report[i];int score = 0, id = student_id[i];while (j < report[i].size()) {string t = "";while (j < report[i].size() && report[i][j] != ' ') {t += report[i][j ++];}j ++;if (S1.count(t)) score -= 3; // 得分,数值变小else if (S2.count(t)) score ++; // 扣分,数值变大}pq.push({score, id});if (pq.size() > k) pq.pop();}int i = k - 1;while (i >= 0) { // while (pq.size() && i >= 0) {int id = pq.top().second;pq.pop();ans[i --] = id;}return ans;}
};

时间复杂度 O ( n l o g k ) O(nlogk) O(nlogk) : n n n r e p o r t report report的长度, k k k 是常数(奖励最顶尖的前k名学生),优先队列内部最多维护 k + 1 k+1 k+1名学生,一共 n n n名学生进一次优先队列,最多 n n n名学生出一次优先队列,时间复杂度 O ( n l o g k ) O(nlogk) O(nlogk)
空间复杂度 O ( n ) O(n) O(n) : 两个哈希集合/ans数组的空间复杂度 O ( n ) O(n) O(n),优先队列的最坏空间复杂度 O ( k ) O(k) O(k),总体空间复杂度 O ( n ) O(n) O(n)

AC

ac

致语
  • 理解思路很重要。
  • 请读者放心留言,可以是疑惑的点,或者感谢/夸奖也可以!!墨染看到会回复的。
http://www.dinnco.com/news/9890.html

相关文章:

  • 安庆网站建设专业制站长工具推荐
  • 杭州网站怎么做seo百度收录提交网址
  • 泉州it培训兰州seo整站优化服务商
  • 京东商城网站风格百度爱采购竞价
  • 建网站添加付款方式中央新闻
  • 岚山网站建设报价营销做得好的品牌
  • 宁波网站建设流程图如何写软文赚钱
  • 北京如何优化网站备案查询网
  • 广告公司经营范围有哪些aso关键词排名优化是什么
  • 专家一对一免费咨询绍兴seo
  • 网站推广软件免费下载网络营销策划是什么
  • 用c 做一个小网站怎么做公司企业网站制作需要多少钱
  • 云南网站制作一条龙全包哪有培训seo
  • win2008做的网站打不开高佣金app软件推广平台
  • 网站案例介绍google chrome 网络浏览器
  • 安徽网站建设公司排名长沙网站推广智投未来
  • 平台网站可以做第三方检测报告阿里巴巴指数查询
  • 网站营销活动策划公关公司
  • 松桃和兴建设公司网站网站定制设计
  • 厦门网站建设是什么意思青岛网站seo分析
  • 无锡网站建设公司长沙网站seo诊断
  • 做网站的相关术语新网
  • 中国军事世界排名盛大游戏优化大师
  • 网站建设的频道是什么百度大数据官网入口
  • 住房和城乡建设厅网站万网阿里云域名查询
  • 做淘宝客需要企业网站吗全网营销推广是什么
  • WordPress用户图片网站seo推广优化
  • 做庭院的网站网络运营团队
  • 网站开发使用的工具珠海百度搜索排名优化
  • 网页微博怎么看直播苏州百度 seo