剑指offer:二维数组的查找

题目描述

在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。

解题思路

因为本题中二维数组每一行是自左向右递增,每一列是自上而下递减的,因此选取左下角为起始比较点tmp

比tmp大的数都在tmp右边,将列坐标+1

比tmp小的数都在tmp上边,将横坐标-1

由此每次可排除一行或一列的数

剑指offer:二维数组的查找

代码

     public boolean Find(int target, int [][] array) {
int rowCount = array.length;
int colCount = array[0].length;
for(int i=rowCount-1,j=0;i>=0&&j<colCount;){
int tmp = array[i][j];
if(target==tmp){
return true;
}else if(target<tmp){
i--;
}else{
j++;
}
}
return false;
}
上一篇:Docker容器学习梳理 - 私有仓库Registry使用


下一篇:剑指offer之 二维数组的查找