力扣1499.满足不等式的最大值

力扣1499.满足不等式的最大值

  • 双端单调队列

    • 将原式变形为 xj + yj + yi - xi
    • 枚举j ,问题变为求i<j的yi - xi的最大值
    • 有限制条件xi ≥ xj−k
    • 单调队列储存二元组(x,y-x)
cpp 复制代码
  class Solution {
  public:
      int findMaxValueOfEquation(vector<vector<int>>& points, int k) {
          int ans = INT_MIN;
          deque<pair<int,int>> q;
          for(auto &p:points)
          {
              int x = p[0],y = p[1];
              //如果队头元素的x不满足条件了
              while(!q.empty() && q.front().first < x - k)
                  q.pop_front();
              //如果还有满足条件的,取队头的最大值
              if(!q.empty())
                  ans = max(ans,x + y + q.front().second);
              //如果队尾元素比当前的小,之前弹掉
              while(!q.empty() && q.back().second <= y - x)
                  q.pop_back();
              q.emplace_back(x,y-x);
          }
          return ans;
      }
  };
相关推荐
TracyCoder1237 小时前
LeetCode Hot100(15/100)——54. 螺旋矩阵
算法·leetcode·矩阵
u0109272718 小时前
C++中的策略模式变体
开发语言·c++·算法
2501_941837268 小时前
停车场车辆检测与识别系统-YOLOv26算法改进与应用分析
算法·yolo
探序基因9 小时前
单细胞Seurat数据结构修改分群信息
数据结构
六义义10 小时前
java基础十二
java·数据结构·算法
四维碎片10 小时前
QSettings + INI 笔记
笔记·qt·算法
Tansmjs10 小时前
C++与GPU计算(CUDA)
开发语言·c++·算法
独自破碎E11 小时前
【优先级队列】主持人调度(二)
算法
weixin_4454766811 小时前
leetCode每日一题——边反转的最小成本
算法·leetcode·职场和发展
打工的小王11 小时前
LeetCode Hot100(一)二分查找
算法·leetcode·职场和发展