二维数组中的查找
在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
这道题需要观察数据的规律,我们会发现从右上角的元素开始比较,就可以轻松判断。如果比右上角的元素大,那么就只能向下着;如果比右上角的元素小,那么只能向左找。
public:
bool Find(int target, vector<vector<int> > array) {
int row=array.size();
int col=array[0].size();
int row_status=0;
int col_status=col-1;
while(row_status<row&&col_status>=0)
{
if(array[row_status][col_status]<target)
row_status++;
else if(array[row_status][col_status]>target)
col_status--;
else
return true;
}
return false;
}