一、题目
在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。
请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
样例
输入数组:
[1,2,8,9],
[2,4,9,12],
[4,7,10,13],
[6,8,11,15]
如果输入查找数值为7,则返回true,
如果输入查找数值为5,则返回false。
二、思路
按照数组的有序性
从左上角开始遍历 比较
三、代码
class Solution {
public:
bool Find(int target, vector<vector<int> > array) {
if(array.empty()||array[0].empty()) // 数组为空的话直接返回
return false;
int i = 0 , j = array[0].size()-1;
// 从数组 右上角开始比较
while(i<array.size()&&j<array[0].size()){
if(array[i][j] == target) return true;
if(array[i][j] < target) i++; // 如果当前位置的数比目标数小 往下移一行即可
else j--;// 如果当前位置的数比目标数大 往左移动
}
return false;
}
};
2504

被折叠的 条评论
为什么被折叠?



