问题描述:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。
请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
例如下面的二维数组就是每行、每列都递增排序。如果在这个数组中查找数字7,则返回true;如果查找数字5,由
于数组不含有该数字,则返回false。
1 2 8 9
2 4 9 12
4 7 10 13
6 8 11 15
分析:首先我们选取数组右上角的数字9。由于9大于7,并且还是第4列的第一个(也是最小的)数字,因此
7不可能出现在数字9所在的列。于是我们把这一列从需要考虑的区域内剔除,之后只需要分析剩下的
3列。在剩下的矩阵中,位于右上角的数字是8。同8大于7因此8所在的列也要剔除。接下来我们要分
析的只有两列。
在剩下的两列组成的数组中,2小于7,因此要查找的数可能在2的右边和下边,因此 可以把2所在的行删除
,同样4小于7,因此也可以把4所在的行也删除,最后只剩下两行两列。位于右上角的刚好就是我们要查
找的数,于是查找过程就结束了。
总结上述查找的过程,我们发现如下规律:首先我们选取数组中右上角的数字。如果数字等于要查找的数字,查找
过程结束;如果该数字大于要查找的数字,剔除这个数字所在的列;如果该数字小于要查找的数字,剔除这个数字
所在的行。也就是说如果要查找的数字不在数组的右上角,则每次都在数组的查找范围中剔除一行或者一列,这样
每一步都可以缩小查找的范围,知道找到要查找的数字,或者查找范围为空。
下面此过程的核心算法:
bool findNumber(int *martix, int rows, int columns, int targetNumber){
bool found = false;
if (martix != NULL && rows > 0 && columns > 0){
int row = 0;
int column = columns - 1;
while (row<rows && column>0)
{
if (martix[row * columns + column] == targetNumber){
found = true;
break;
}
else if (martix[row * columns + column] > targetNumber){
--column;
}
else{
++row;
}
}
}
return found;
}
输入示例进行验证:
#include<iostream>
using namespace std;
bool findNumber(int *martix, int rows, int columns, int targetNumber);
int main(){
int vector[4][4] = { 1,2,8,9,2,4,9,12,4,7,10,13,6,8,11,15 };//二维数组的数组名是指向指针的指针。
bool result = findNumber(vector[0], 4, 4, 7);
cout << "true or false :" << result;
system("pause");
return 0;
}
输出结果是:
true or false :1