力扣2503.矩阵查询可获得的最大分数

力扣2503.矩阵查询可获得的最大分数

  • 离线算法 + 排序 + 小根堆

    • 将query数组从小到大排序,用小根堆存每个单元格的值
    • 从小到大遍历query,如果堆顶元素小于query[i],弹出,直到全部弹出,总弹出个数为答案
cpp 复制代码
  class Solution {
      int dx[4] = {0,1,0,-1},dy[4] = {1,0,-1,0};
  public:
      vector<int> maxPoints(vector<vector<int>>& grid, vector<int>& queries) {
          int k = queries.size(),id[k];
          iota(id,id+k,0);
          sort(id,id+k,[&](int i,int j){return queries[i] < queries[j];});
  
          vector<int> ans(k);
          priority_queue<tuple<int, int, int>, vector<tuple<int, int, int>>, greater<>> pq;
          pq.emplace(grid[0][0],0,0);
          grid[0][0] = 0;
          int m = grid.size(),n = grid[0].size(),cnt=0;
          for(int qi:id)
          {
              //堆顶元素更小
              int q = queries[qi]; 	
              //tuple的语法,get<0>(tuple) 返回tuple的第一个元素的引用
              while(!pq.empty() && get<0>(pq.top()) < q)
              {
                  cnt ++;
                  auto[_,tx,ty] = pq.top();
                  pq.pop();
                  for(int i=0;i<4;i++)
                  {
                      int x = tx + dx[i],y = ty + dy[i];
                      if (0 <= x && x < m && 0 <= y && y < n && grid[x][y]) 
                      {
                          pq.emplace(grid[x][y],x,y);
                          grid[x][y] = 0;
                      }
                  }
              }
              ans[qi] = cnt;
          }
          return ans;
      }
  };
相关推荐
中华小当家呐31 分钟前
算法之常见八大排序
数据结构·算法·排序算法
沐怡旸1 小时前
【算法--链表】114.二叉树展开为链表--通俗讲解
算法·面试
一只懒洋洋2 小时前
K-meas 聚类、KNN算法、决策树、随机森林
算法·决策树·聚类
方案开发PCBA抄板芯片解密3 小时前
什么是算法:高效解决问题的逻辑框架
算法
songx_993 小时前
leetcode9(跳跃游戏)
数据结构·算法·游戏
小白狮ww3 小时前
RStudio 教程:以抑郁量表测评数据分析为例
人工智能·算法·机器学习
AAA修煤气灶刘哥3 小时前
接口又被冲崩了?Sentinel 这 4 种限流算法,帮你守住后端『流量安全阀』
后端·算法·spring cloud
沧海一粟青草喂马4 小时前
抖音批量上传视频怎么弄?抖音矩阵账号管理的专业指南
大数据·人工智能·矩阵
kk”4 小时前
C语言快速排序
数据结构·算法·排序算法
纪元A梦4 小时前
贪心算法应用:基因编辑靶点选择问题详解
算法·贪心算法