博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
二维数组中的查找
阅读量:5825 次
发布时间:2019-06-18

本文共 977 字,大约阅读时间需要 3 分钟。

题目:

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

  array: 待查找的二维数组target:查找的数字。查找到返回true,查找不到返回false。

思路:      1  2  8   9

      2  4  9   12

         4  7 10  13

         6  8 11  15

  例如上面的二维数组,因为数组是部分有序的,所以很快会想到用二分或者二叉查找树,如果以9为根节点看的话,整个二维矩阵就是一棵二叉查找树。利用这个思想就可以降低时间复杂度。比如要找的数是7,则从9开始,9>7所以把9所在的列去掉,列指针左移,8>7同样的操作,2<7把2所在行去掉,行指针下移,4<7同样的操作,7==7返回true。这个思路明白了,边界情况稍加考虑代码很容易些出来。当然以6开始也满足二叉查找树的情况,但是左上角和右下角就不满足了。

实现代码:

public class Solution {    public boolean Find(int [][] matrix,int t) {                if(matrix == null || matrix.length == 0 || matrix[0].length == 0)            return false;                int row = 0;        int col = matrix[0].length - 1; //从右上角开始        while(row < matrix.length && col >= 0) {            if(matrix[row][col] == t)                return true;            else if(matrix[row][col] > t) {                col --;            }            else {                row ++;            }        }                return false;    }}

 

转载地址:http://kjsdx.baihongyu.com/

你可能感兴趣的文章
计划10年建10万廉价屋 新西兰政府:比想象中难
查看>>
甘肃发首版《3D打印职业教育教材》:校企合作育专才
查看>>
韩国国会议员涉嫌投机炒房 检方称已立案调查
查看>>
李娜入选国际网球名人堂 成亚洲第一人
查看>>
为找好心人抚养孩子 浙江一离婚父亲将幼童丢弃公园
查看>>
晚婚晚育 近20年巴西35岁以上孕妇增加65%
查看>>
读书:为了那个美妙的咔哒声
查看>>
我从过去八个月的AI公司面试中学到了什么?
查看>>
jQuery实践小结
查看>>
深入探究Immutable.js的实现机制(一)
查看>>
jsp改造之sitemesh注意事项
查看>>
智能硬件的时代,嵌入式是否已经日薄西山
查看>>
单点登录(SSO)看这一篇就够了
查看>>
SpringBoot-Shiro使用
查看>>
分布式理论:CAP是三选二吗?
查看>>
iOS 9.0之后NSString encode方法替换
查看>>
解决 ThinkPHP5 无法接收 客户端 Post 传递的 Json 参数
查看>>
ASMFD (ASM Filter Driver) Support on OS Platforms (Certification Matrix). (文档 ID 2034681.1)
查看>>
gitlab 账号注册及修改资料
查看>>
pxssh交换机自动刷限速模板
查看>>