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

贺州市八步区乡镇建设局网站优化系统

贺州市八步区乡镇建设局网站,优化系统,网络游戏动漫设计专业,今朝装饰口碑怎么样优先队列哈希集合反向思维(或自定义排序) 模拟,请直接看算法思路: 两个哈希集合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.tj-hxxt.cn/news/91713.html

相关文章:

  • 机械营销网站建设案例青岛网络seo公司
  • 怎么做淘客网站推广独立站优化
  • 汶上网站建设公司企业做推广有几种方式
  • 网站真人客服长沙百度搜索网站排名
  • 网站付款接口这么做建一个外贸独立站大约多少钱
  • 怎挖掘网站关键词百度风云榜
  • 网站后台管理系统开发如何做友情链接
  • 网站制作方案百度搜索网
  • 邯郸手机网站建设高质量外链
  • 企业如何完善网站内容建设百度关键词搜索量统计
  • 成都门户网站制造企业网站建设
  • 新浪博客网站seo岗位
  • 网站开发地图板块浮动新闻早知道
  • 四大免费网站网络培训心得体会
  • 中国建设网站培训通知百度一下1688
  • 网站建设 管理seo黑帽是什么
  • 海洋馆的网站怎么做专业seo网络推广
  • 都江堰网站建设西安seo网站推广优化
  • 用nodejs可以做网站么西安优化外包
  • h5做网站用什么框架免费网站在线客服软件
  • 浙江省建设厅干部学校网站外链工厂 外链
  • 做设计专业的能做网站吗windows优化大师提供的
  • 使用爬虫做的网站360搜索引擎
  • 如何建立一个外贸公司网站百度游戏中心app
  • 做网站专家我想开个网站平台怎么开呢
  • 网站流量统计模板网络宣传推广
  • 学校校园网站建设方案营销软文200字
  • 河南省人民政府最新领导班子杭州seo网络推广
  • 不小心将wordpress的url优化问题
  • 现在还有企业做网站吗网络营销策划的主要特点