题目链接
题目描述
在一个二维数组中(每个一维数组的长度相同)
- 每一行都按照从左到右递增 的顺序排序,
- 每一列都按照从上到下递增 的顺序排序。
请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
示例
现有矩阵 matrix 如下:
[[1, 4, 7, 11, 15],[2, 5, 8, 12, 19],[3, 6, 9, 16, 22],[10, 13, 14, 17, 24],[18, 21, 23, 26, 30]]
- 给定 target = 5,返回 true。
- 给定 target = 20,返回 false。
解题思路
二维数组是有规律的:右上角的数字是一列中最小的、一行中最大的,通过这个数字和 target 进行对比,可以将一行或者一列作为候选区域排出,那么 target 可能存在的范围缩小,最终得出结果。
代码
public class Solution {public boolean Find(int target, int [][] array) {if(array.length==0){return false;}//定义右上角坐标int i=0,j=array[0].length-1;for(;i<=array.length-1&&j>=0;){if(array[i][j] > target){j--;}else if(array[i][j] < target){i++;}else{return true;}}return false;}}
代码分析
首先定义右上角坐标 ( i =0 , j = array[0].length-1 )
因为每一行的比较都需要从最大的地方开始
循环条件中,因为横坐标是一直往大变,即i++ , 纵坐标是一直往小变,即 j—
所以循环条件中, i <= array.length-1 && j >= 0
