二维数组中的查找-自编java版本。
2016-01-16 04:13
211 查看
网上的题。剑指offer的。
[b]输入描述:[/b]
[b]输出描述:[/b]
调试截图一枚:
题目描述
在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。[b]输入描述:[/b]
array: 待查找的二维数组 target:查找的数字
[b]输出描述:[/b]
查找到返回true,查找不到返回false
原理(复制大牛的。但是他不是用java编的):从右上方的数字开始,如果该数字比查找的数字小,那么该数字所在行可以删除,不用继续考虑;如果该数字比查找的数字大,那么该数字所在列可以删除。这样,每次执行,都会删除一行或者一列,极端情况下,执行2n次。
package ab; /** * Created by dell on 2016/1/15. */ public class ab { public static final void main(String[] args) { //,[[1,2,8,9],[2,4,9,12],[4,7,10,13],[6,8,11,15]] //int[][] b = {{1, 2, 8,9}, {2,4, 9, 12}, {4,7, 10, 13},{6,8,11,15}}; int[][] b = {{1, 2, 8,9}, {2,4, 9, 12}, {4,7, 10, 13},{6,8,11,15}}; ab e = new ab(); int i = 5; e.Find(b, i); System.err.print("end1"); } public boolean Find(int[][] array, int target) { int m = array.length; int n = array[0].length; m--; n--; System.err.print(array[m-1][n-2]); int line = 0; int row = n; while (line < m && row > 0) { if (target > array[line][row]) { line++; } else if (target < array[line][row]) { row--; } else { return true; } } while (row==0 && line<=m ){ if (target > array[line][0]){ line++; }else if (target < array[line][0]){ return false; }else { return true; } } while (line ==m && row > 0){ if (target > array[m][row]){ return false; }else if (target < array[m][row]){ row--; }else { return true; } } return false; } }
调试截图一枚:
相关文章推荐
- Java多线程学习笔记(三)同步和异步
- spring+mybatis所需各种服务的搭建
- Eclipse安装SVN插件
- Perhaps you are running on a JRE rather than JDK
- moon.1 JAVA 耦合与内聚
- 关于Java文件删除的操作
- CXF Spring开发WebService,基于SOAP和REST方式
- Java图形界面设计——substance皮肤
- java随机数:彩票抽奖 + 验证码
- Struts,Hibernate,Spring经典面试题
- Spring面试问答Top 25
- java多线程下载文件
- Spring3 @ResponseBody注解引起头部Accept-Charset过大
- Spring MVC
- Javaweb和spring和springmvc和maven使用记录
- 使用maven创建javaweb项目
- javaWeb项目编码问题探索
- Eclipse-----Eclipse设置字体
- eclipse快捷键大全
- Eclipse使用笔记