题目描述
在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
解题思路
参考github: https://github.com/CyC2018/CS-Notes
一开始的想法就是很直接的,直接一行行的查找,因此时间复杂度也相对会大一些,尽管也能够通过,但却是最笨的方法。下面写写时间复杂度为O(M+N)+O(1)的写法。
从右上角开始查找。矩阵中的一个数,它左边的数都比它小,下边的数都比它大。因此,从右上角开始查找,就可以根据 target 和当前元素的大小关系来缩小查找区间。
1 | class Solution { |