每一次选取数组查找范围内右上角的那个数,如果该数字等于要查找的数,查找过程结束;如果该数字大于要查找的数,那么该列所有数都大于要查找的数字,剔除这个数字所在的列;如果该数字小于要查找的数字,那么该行所有数都小于要查找的数字,剔除这个数字所在的行。这样每一步都可以缩小查找范围,直到找到要查找的数字,或者查找范围为空。
#include<iostream>
using namespace std;
bool Find(int *a, int rows, int columns, int number)
{
bool found = false;
if (a != NULL&&rows > 0 && columns > 0)
{
int row = 0;
int column = columns - 1;
while (row < rows&&column>0)
{
if (a[row*columns + column] == number)
{
found = true;
break;
}
else if (a[row*columns + column] > number)
--column;
else
++row;
}
}
return found;
}
int main()
{
int a[4][4] = { { 1, 2, 8, 9 }, { 2, 4, 9, 12 }, { 4, 7, 10, 13 }, { 6, 8, 11, 15 } };
cout << Find(&a[0][0], 4, 4, 7) << endl;
}