力扣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])};
      }
  };
相关推荐
__Coffee__16 分钟前
封装矩阵结构体
线性代数·算法·矩阵
变量未定义~24 分钟前
字符串哈希匹配字符串
数据结构·算法·哈希算法
周末也要写八哥28 分钟前
浅谈二叉树的深度优先搜索(DFS)算法
算法·深度优先
天真小巫35 分钟前
2026.5.17总结
职场和发展
凯瑟琳.奥古斯特37 分钟前
信号分类与特性解析
java·开发语言·职场和发展
y = xⁿ39 分钟前
20天速通LeetCodeday17:一维动态规划
算法
sheeta199841 分钟前
LeetCode 每日一题笔记 日期:2026.05.17 题目:1306. 跳跃游戏 III
笔记·leetcode
bnmoel44 分钟前
数据结构深度剖析栈与队列:结构、边界实现与进出操作全解析
c语言·数据结构·算法··队列
WL_Aurora1 小时前
Python 算法基础篇之查找算法(一):顺序查找、二分查找与插值查找
开发语言·python·算法
ChoSeitaku1 小时前
06_可变参数_递归_类和对象_封装
java·数据结构·算法