算法面试真题详解: 寻找峰值 II

简介: 算法面试真题详解: 寻找峰值 II

描述
给定一个整数矩阵 A, 它有如下特性:
相邻的整数不同
矩阵有 n 行 m 列,n和m不会小于3。
对于所有的 i < n, 都有 A[i][0] < A[i][1] && A[i][m - 2] > A[i][m - 1]
对于所有的 j < m, 都有 A[0][j] < A[1][j] && A[n - 2][j] > A[n - 1][j]
我们定义一个位置 [i,j] 是峰值, 当且仅当它满足:
A[i][j] > A[i + 1][j] && A[i][j] > A[i - 1][j] &&
A[i][j] > A[i][j + 1] && A[i][j] > A[i][j - 1]

找到该矩阵的一个峰值元素, 返回它的坐标.
保证至少存在一个峰值, 而如果存在多个峰值, 返回任意一个即可.

在线评测地址:领扣题库官网

样例 1:
输入: 
    [
      [1, 2, 3, 6,  5],
      [16,41,23,22, 6],
      [15,17,24,21, 7],
      [14,18,19,20,10],
      [13,14,11,10, 9]
    ]
输出: [1,1]
解释: [2,2] 也是可以的. [1,1] 的元素是 41, 大于它四周的每一个元素 (2, 16, 23, 17).
样例2:
输入: 
    [
      [1, 5, 3],
      [4,10, 9],
      [2, 8, 7]
    ]
输出: [1,1]
解释: 只有这一个峰值

挑战
O(n+m) 的时间复杂度.
如果你 认为 你使用了 O(nlogm) 或 O(mlogn) 的算法, 能否证明它的复杂度其实是 O(n+m)? 或者想一个类似的算法但是复杂度是O(n+m)?

解题思路
峰值不是最大值,只是比四个方向上的数值都大,是局部性的最值。
对于每一个点,它总能属于某一座山峰(可以不止一座)。
找峰值可以想象成爬山,总是要不断的从低处向高处移动,这样移动到最后一定是峰值。
代码思路
在图上随机取一点,若有相邻位置比当前点大则向该相邻位置移动,直到当前点成为峰值。
最坏情况是螺旋式上升,且随机在了起点位置,那么就要爬升一半的点
1 2 3 4 5
0 0 0 0 6
15 16 17 0 7
14 0 0 0 8
13 12 11 10 9
如果遇到最坏的情况,我们可以通过当爬升超过一定距离后重新随机一个点,使得相对平均效率较高

复杂度分析

NN表示行数,MM表示列数
空间复杂度:O(1)
平均时间复杂度:O(N+M)

public class Solution {

    /*

     * @param A: An integer matrix

     * @return: The index of the peak

     */

    public List<Integer> findPeakII(int[][] A) {

        int n = A.length;

        int m = A[0].length;

        int now_x, now_y, next_x, next_y;

        //这里初始位置选择为中心位置

        now_x = n / 2;

        now_y = m / 2;

        while (1 == 1) {

            next_x = now_x;

            next_y = now_y;

            //四个方向上若有比当前位置大的,则向该方向移动

            if (now_x + 1 < n && A[now_x + 1][now_y] > A[next_x][next_y]) {

                next_x = now_x + 1;

                next_y = now_y;

            }else if (now_x - 1 >= 0 && A[now_x - 1][now_y] > A[next_x][next_y]) {

                next_x = now_x - 1;

                next_y = now_y;

            }else if (now_y + 1 < m && A[now_x][now_y + 1] > A[next_x][next_y]) {

                next_x = now_x;

                next_y = now_y + 1;

            }else if (now_y-1 >= 0 && A[now_x][now_y - 1] > A[next_x][next_y]) {

                next_x = now_x;

                next_y = now_y - 1;

            }

            //若四个方向上都比当前位置小,即为峰值直接返回答案

            if (next_x == now_x && next_y == now_y) {

                return new ArrayList<Integer>(Arrays.asList(now_x, now_y));

            }

            now_x = next_x;

            now_y = next_y;

        }

    }

}

更多题解参考:九章官网solution

相关文章
|
23天前
|
存储 算法 编译器
米哈游面试算法题:有效的括号
米哈游面试算法题:有效的括号
23 0
|
2月前
|
开发框架 算法 搜索推荐
C# .NET面试系列九:常见的算法
#### 1. 求质数 ```c# // 判断一个数是否为质数的方法 public static bool IsPrime(int number) { if (number < 2) { return false; } for (int i = 2; i <= Math.Sqrt(number); i++) { if (number % i == 0) { return false; } } return true; } class Progr
60 1
|
23天前
|
负载均衡 算法 应用服务中间件
面试题:Nginx有哪些负载均衡算法?Nginx位于七层网络结构中的哪一层?
字节跳动面试题:Nginx有哪些负载均衡算法?Nginx位于七层网络结构中的哪一层?
35 0
|
2天前
|
存储 缓存 算法
面试遇到算法题:实现LRU缓存
V哥的这个实现的关键在于维护一个双向链表,它可以帮助我们快速地访问、更新和删除最近最少使用的节点,同时使用哈希表来提供快速的查找能力。这样,我们就可以在 O(1) 的时间复杂度内完成所有的缓存操作。哈哈干净利索,回答完毕。
|
5天前
|
算法 数据可视化 Java
数据结构与算法-单向链表的实现以及相关面试题
数据结构与算法-单向链表的实现以及相关面试题
7 0
|
15天前
|
算法 搜索推荐 Python
数据结构与算法在Python面试中的应用实例
【4月更文挑战第13天】本文聚焦Python面试中的数据结构与算法问题,包括排序算法、链表操作和树图遍历。重点讨论了快速排序、链表反转和二叉树前序遍历的实现,并指出理解算法原理、处理边界条件及递归操作是避免错误的关键。通过实例代码和技巧分享,帮助面试者提升面试表现。
13 0
|
16天前
|
设计模式 算法 Java
如何在面试中应对编程与算法面试?
面试中,编程能力至关重要,主要分为三个层次:初级关注基本功,如语法、原理和常见问题解决;高级涉及数据结构与算法,基础算法如排序对中小厂重要,大厂则需深入数据结构;资深专家层次需精通设计模式,以保证代码的扩展性和维护性。提升编程技能可采用PDCA循环学习法,从计划到执行、检查、行动不断迭代。通过实践项目如开发后端系统、测试框架来检验学习成果,并逐步学习算法和设计模式。坚持不懈的努力和重构将助你成为技术专家。记住,超越大多数人的关键在于持续学习和专注深耕。
7 0
如何在面试中应对编程与算法面试?
|
2月前
|
算法
覃超老师 算法面试通关40讲
无论是阿里巴巴、腾讯、百度这些国内一线互联网企业,还是 Google、Facebook、Airbnb 等硅谷知名互联网公司,在招聘工程师的过程中,对算法和数据结构能力的考察都是重中之重。本课程以帮助求职者在短时间内掌握面试中最常见的算法与数据结构相关知识点,学会面试中高频算法题目的分析思路,同时给大家从面试官的角度来分析算法题的解答技巧,从而更有效地提升求职者的面试通过率。
15 3
覃超老师 算法面试通关40讲
|
2月前
|
存储 算法
【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解
【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解
|
2月前
|
存储 机器学习/深度学习 算法
python常用算法,新手必会,面试必出
python常用算法,新手必会,面试必出
37 0