剑指Offer:面试题3——二维数组中的查找(java实现)
来源:互联网 发布:淘宝 投诉卖家 编辑:程序博客网 时间:2024/06/01 10:14
问题描述:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数.
思路:取数组中的元素与目标整数比较,相等则返回true,小于则 查找当前元素的右方和下方,大于则查找当前元素的左方和上方,然而这两个区域有重叠部分,就不容易处理。
然而如果我们从数组的角落选取元素与目标整数对比,则就不会出现重叠区域了。
假如:我们从右上角选取元素,如果相等则返回true;如果大于,显然该列的元素都大于目标整数,我们就可以去掉这一列然后对比剩下的前几列;如果小于,显然该行的所有元素都小于目标整数,我们就可以去掉这一行然后对比剩下的后几行。依次类推,即可找到或找不到相应的目标整数。
/** * 面试题3:二维数组中的查找 */ public static boolean Find(int[][] mat, int number){ boolean found = false; if(mat != null && mat.length() > 0 && mat[0].length() > 0){ int m = mat.length(); int n = mat[0].length(); int row = 0; int col = n-1; while(row < m && col >=0){ if(mat[row][col] == number){ found = true; break; }else if(mat[row][col] > number){ col--; }else{ row++; } } } return found; }
0 0
- 剑指Offer:面试题3——二维数组中的查找(java实现)
- 剑指offer面试题3—二维数组中的查找(Java实现)
- 剑指offer面试题3—二维数组中的查找
- 剑指Offer——面试题3:二维数组中的查找(Java)
- 剑指offer|面试题3:二维数组中的查找(Java实现)
- 二维数组中的查找(剑指offer面试题3)
- 剑指offer面试题java实现之题3:二维数组中的查找
- 剑指offer面试题3:二维数组中的查找 java实现
- 剑指offer面试题3 二维数组中的查找 (java)
- 剑指Offer面试题3(Java版):二维数组中的查找
- 剑指Offer面试题3(Java版):二维数组中的查找
- 【剑指offer】2.3.1 数组——面试题3:二维数组中的查找
- 剑指offer面试题3 二维数组的查找(java实现)
- 【剑指offer】面试题3:二维数组中的查找
- 【剑指offer】面试题3:二维数组中的查找
- 剑指Offer:面试题3 二维数组中的查找
- 《剑指Offer》面试题3:二维数组中的查找
- 剑指offer面试题3-二维数组中的查找
- 视图VIEW整理
- redis源码分析之数据结构(一)链表adlist.c
- android 调用摄像头实现
- 一个功能增强的Delphi TListView组件
- 平行模块思考和模块双向关系思考
- 剑指Offer:面试题3——二维数组中的查找(java实现)
- CrackingtheCodeInterview之智力题
- 复制指定目录下的指定文件,并修改后缀名代码
- Java agent实现JVM exception 统计
- 面试?顺谈Java程序员学习中各阶段的建议
- Spring任务调度器之Task的使用
- Spring切面
- 空间换时间设计-多索引结构实现高效查询算法
- linux 目录大小