题目描述
在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
解题思路
当我们需要解决一个复杂的问题时,一个很有效的办法就是从一个具体的问题入手,通过分析简单具体的例子,试图寻找普遍的规律。
首先我们选取数组右上角的数字9。由于 9 大于 7,并且 9 还是第四列的第一个(也是最小的)数字,因此 7 不可能出现在数字 9 所在的列。于是我们把这一列从需要考虑的区域内剔除,之后只需要分析剩下的 3 列。在剩下的矩阵中,位于右上角的数字是 8。同样 8 大于 7,因此 8 所在的列我们也可以剔除。接下来我们只要分析剩下的两列即可。
总结上述查找的过程,我们发现如下规律:首先选取数组中右上角的数字。如果该数字等于要查找的数字,查找过程结束;如果该数字大于要查找的数字,剔除这个数字所在的列;如果该数字小于要查找的数字,剔除这个数字所在的行。也就是说如果要查找的数字不在数组的右上角,则每一次都在数组的查找范围中剔除一行或者一列,这样每一步都可以缩小查找的范围,直到找到要查找的数字,或者查找范围为空。
python 代码实现:
# -*- coding:utf-8 -*-
class Solution:
# array 二维列表
def Find(self, target, array):
# write code here
row=len(array)
col=len(array[0])
if row > 0 and col > 0:
i = 0
j = col -1
while i < row and j >= 0:
if array[i][j] == target:
return True
elif array[i][j] > target:
j = j - 1
else:
i = i + 1
return False
c 代码实现:
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 = column - 1;
while (row < rows && column >= 0)
{
if (matrix[row * column + column] == number)
{
found = true;
break;
}
else if (matrix[row * columns + column] > number)
--column;
else:
++row;
}
}
return found
}
考察应聘者分析问题的能力。当应聘者发现问题比较复杂时,能不能通过具体的例子找出其中的规律,是能否解决这个问题的关键所在。
这个题目只要从一个具体的二维数组的右上角开始分析,就能找到查找的规律,从而找到解决问题的突破口。

本文介绍了一种在特殊排序的二维数组中查找特定整数的方法。通过从数组的右上角开始,逐步排除行列来缩小搜索范围,最终实现高效查找。
607

被折叠的 条评论
为什么被折叠?



