您的位置:首页 > 其它

二维数组中的查找

2015-09-15 17:11 302 查看
题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。

方法:首先选取数组中右上角的数字。如果该数字等于要查找的数字,查找过程结束;如果该数字大于要查找的数字,剔除这个数字所在的列(向左移);如果该数字小于要查找的数字,剔除这个数字所在的行(向下移)。如下所示:



bool Find(int* matrix, int rows, int columns, int number){
bool found = false;

if (matrix != NULL && rows > 0 && columns > 0){
int row = 0;
int column = columns - 1;
while (row < rows && column >= 0){
if (matrix[row * columns + column] == number){
found = true;
break;
}
else if (matrix[row * columns + column] > number){
-- column;
}
else {
++ row;
}
}
}
return found;
}


测试用例

二维数组中包含查找的数字(查找的数字是数组中的最大值和最小值,查找的数字介于数组中的最大值和最小值之间)。

二维数组中没有查找的数字(查找的数字大于数组中的最大值,查找的数字小于数组中的最小值,查找的数字在数组的最大值和最小值之间但数组中没有这个数字)。

特殊输入测试(输入空指针)。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  查找