C++實現在二維數組中的查找

2019-10-19     科技i關注

今天小編在網上看到一道小題目,是關於在二維數組中的查找,帶大家一起來學習一下,感興趣的好好看看,附上代碼可以仿照編寫一下哦!



題目:

在一個二維數組中,每一行都按照從左到右遞增的順序排序,每一列都按照從上到下遞增的順序排序。請完成一個函數,輸入這樣的一個二維數組和一個整數,判斷數組中是否含有該整數。

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++實現在二維數組中的查找的詳細內容,更多請關注其它相關文章!

更多技巧請《轉發 + 關注》哦!

文章來源: https://twgreatdaily.com/MbIQ4G0BMH2_cNUgSSBo.html