参考官方题解做出来的,感谢官方题解,这种方法真的很高效。
class Solution {
public:
bool Find(int target, vector<vector<int> > array) {
if(!array.size()) return false;
int r = 0, c = array[0].size()-1;
while(r< array.size()&&c>=0){//退出条件(r从0一直找到末尾,c从最后一列一直找到第一列)
if(target == array[r][c]){
return true;
}else if(target< array[r][c]){
c--;
}else{
r++;
}
}
return false;
}
};
京公网安备 11010502036488号