今天小編在網上看到一道小題目,是關於在二維數組中的查找,帶大家一起來學習一下,感興趣的好好看看,附上代碼可以仿照編寫一下哦!
題目:
在一個二維數組中,每一行都按照從左到右遞增的順序排序,每一列都按照從上到下遞增的順序排序。請完成一個函數,輸入這樣的一個二維數組和一個整數,判斷數組中是否含有該整數。
1、思路
首先選取數組中右上角的數字。如果該數字等於要查找的數字,查找過程結束;如果該數字大於要查找的數組,剔除這個數字所在的列;如果該數字小於要查找的數字,剔除這個數字所在的行。也就是說如果要查找的數字不在數組的右上角,則每一次都在數組的查找範圍中剔除一行或者一列,這樣每一步都可以縮小查找的範圍,直到找到要查找的數字,或者查找範圍為空。
2、舉例
如果在一個二維數組中找到數字7,則返回true,如果沒有找到,則返回false。
1 2 8 9
2 4 9 12
4 7 10 13
6 8 11 15
查找過程如下:
3、編程實現
class Solution {
public:
bool Find(int target, vector> array) {
int rows = array.size();
int cols = array[0].size();
if(!array.empty() && rows > 0 && cols > 0){
int row = 0;
int col = cols - 1;
while(row < rows && col >= 0){
if(array[row][col] == target){
return true;
}
else if(array[row][col] > target){
--col;
}
else{
++row;
}
}
}
return false;
}
};
【推薦課程:C++視頻教程】
以上就是C++實現在二維數組中的查找的詳細內容,更多請關注其它相關文章!
更多技巧請《轉發 + 關注》哦!