力扣1901.寻找峰值II

力扣1901.寻找峰值II

    • 二分每一行 并用函数找出每一行中最大值的下标
    • 若最大值比其下面相邻的元素大 则上方一定存在峰值
    • 若最大值比其下面相邻的元素小 则下方一定存在峰值
cpp 复制代码
  class Solution {
      int indexmax(vector<int> &a)
      {
          return max_element(a.begin(),a.end()) - a.begin();
      }
  public:
      vector<int> findPeakGrid(vector<vector<int>>& mat) {
          int l = 0,r = mat.size() - 1;
          while(l < r)
          {
              //行
              int i = l + r >> 1;
              //列
              int j = indexmax(mat[i]);
              if(mat[i][j] > mat[i+1][j]) r = i;
              else l = i + 1;
          }
          return {l,indexmax(mat[l])};
      }
  };
相关推荐
Lisssaa5 分钟前
打卡第二十八天
数据结构·算法
小此方9 分钟前
算法实战论01(双指针篇一):双指针的核心思想与应用场景总结
c++·算法·力扣
2401_8785302113 分钟前
C++与FPGA协同设计
开发语言·c++·算法
2301_8145902515 分钟前
C++中的装饰器模式实战
开发语言·c++·算法
weixin_6495556722 分钟前
C语言程序设计第四版(何钦铭、颜晖)第十一章指针进阶之查找星期
数据结构·算法
2301_8042154132 分钟前
模板元编程应用场景
开发语言·c++·算法
实心儿儿36 分钟前
C++ —— 红黑树
java·开发语言·算法
炘爚38 分钟前
C++(普通指针和成员的区别、指针的使用场景和存储内容)
数据结构·c++·算法
炘爚41 分钟前
C++(在Mystring类中碰到的构造函数和析构函数以及深拷贝和浅拷贝的问题)
开发语言·c++·算法