剑指offer系列——二维数组中,每行从左到右递增,每列从上到下递增,设计算法找其中的一个数
题目:二维数组中,每行从左到右递增,每列从上到下递增,设计一个算法,找其中的一个数
分析:
二维数组这里把它看作一个矩形结构,如图所示:
|
1 |
2 |
8 |
9 |
|
2 |
4 |
9 |
12 |
|
4 |
7 |
10 |
13 |
|
6 |
8 |
11 |
15 |
在做这道题的时候我最先考虑的是每次比较对角线上的元素可能可以取得较好的效果,
以查找9为例,
从1(0,0)开始,1<10,可以得出结论,10在1的右侧或下侧;
|
1 |
2 |
8 |
9 |
|
2 |
4 |
9 |
12 |
|
4 |
7 |
10 |
13 |
|
6 |
8 |
11 |
15 |
然后看4(1,1),4<9,
|
1 |
2 |
8 |
9 |
|
2 |
4 |
9 |
12 |
|
4 |
7 |
10 |
13 |
|
6 |
8 |
11 |
15 |
然后看10(2,2),10>9,这个时候可以确定在10的右上方,或者左下方,
|
1 |
2 |
8 |
9 |
|
2 |
4 |
9 |
12 |
|
4 |
7 |
10 |
13 |
|
6 |
8 |
11 |
15 |
然后可以考虑使用递归黄色的两个方框,设an>x时是(x,y),an-k>x时是(x0,y0),那么此次递归的起始点因该是:右上(x,y0),左下(x0,y)。
左下的方框,4(2,0),4<9;再看8(3,1),8<10,可以确定不在左下方框;
右上的方框,8(0,2),8<9;再看12(1,3),12>9,再次递归,(1,2)或(0,3)都可以找到。
看似可以解决问题,但是,这个时候的矩形必须是正方形才行。。。。。。
如上图所示,就没办法了(当然,可以通过宽高的关系,计算出选择纵向移动多少次,横向移动 多少次,可以正好走个对角,但是,太麻烦了。。。。),所以,这么想是不对滴。。。。。。
然后我们考虑可以通过比较一次后可以去掉一行或者一列,那这个方法也可以算不错的了。
以查找10为例,
1.如果从左上角开始找,1<10,发现除了一个个往后比没有什么更好的办法了 ;
2.如果从右上角(0,3)开始找,9<10,由于每行从左到右递增,所以可以把第一行(0)排除掉了;
|
1 |
2 |
8 |
9 |
|
2 |
4 |
9 |
12 |
|
4 |
7 |
10 |
13 |
|
6 |
8 |
11 |
15 |
然后看第二行最后一个数(1,3),12>10,由于每列从上到下递增,所以可以把最后一列(3)排除;
|
1 |
2 |
8 |
9 |
|
2 |
4 |
9 |
12 |
|
4 |
7 |
10 |
13 |
|
6 |
8 |
11 |
15 |
然后看(1,2),9<10,排除行1;
|
1 |
2 |
8 |
9 |
|
2 |
4 |
9 |
12 |
|
4 |
7 |
10 |
13 |
|
6 |
8 |
11 |
15 |
然后看(2,2),10==10,找到目标,返回行列号。
3.除了从右上角开始分析有较好的效果外,可以发现从左下角也可以以经过一次比较排除一行或者是一列;从右下角分析则同1一样,效率不高。
代码:
package study;
/**
* 二维数组中,每行从左到右递增,每列从上到下递增,
* 设计一个算法找其中的一个数
* @author cnx
* @CreateDate ; 2014年9月28日 上午10:14:21
*/
public class FindInMatrix {
public static void main(String[] args) {
FindInMatrix f = new FindInMatrix();
int a[] = f.find(f.a1, 12);
if(a!=null)
System.out.println("a1 find 12. row= "+a[0]+"; col="+a[1]);
a = f.find(f.a2, 18);
System.out.println("a2 find 18. row= "+a[0]+"; col="+a[1]);
a = f.find(f.a2, 2);
System.out.println("a2 find 2. row= "+a[0]+"; col="+a[1]);
a = f.find(f.a2, 7);
System.out.println("a2 find 7. row= "+a[0]+"; col="+a[1]);
} public int a1 [][] = null;
public int a2 [][] = {{1,2,8,9},{2,4,9,12},{4,7,10,13},{6,8,11,15}}; //查找18,2,7 public int[] find(int a[][], int des){
//存行列数
int result[] = {-1,-1}; if(a != null && a.length>0 && a[0].length>0){
int row = 0;
int col = a[0].length-1;
while (row<a.length && col>=0) {
// System.out.println(a.length + " ," +a[0].length);
if (a[row][col] == des) {
result[0] = row;
result[1] = col;
break;
}
if (a[row][col] > des) {
col--;
}
else {
row++;
}
}
}
else
result = null; return result;
} }
剑指offer系列——二维数组中,每行从左到右递增,每列从上到下递增,设计算法找其中的一个数的更多相关文章
- 剑指offer:二维数组中的查找
目录 题目 解题思路 具体代码 题目 题目链接 剑指offer:二维数组中的查找 题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺 ...
- 剑指 Offer 04. 二维数组中的查找 (思维)
剑指 Offer 04. 二维数组中的查找 题目链接 本题的解法是从矩阵的右上角开始寻找目标值. 根据矩阵的元素分布特性, 当目标值大于当前位置的值时将row行号++,因为此时目标值一定位于当前行的下 ...
- [剑指Offer]5.二维数组中的查找
题目 在一个二维数组中,每一行都依照从左到右递增的顺序排序,每一列都依照从上到下递增的顺序排序.请完毕一个函数,输入这种一个二维数组和一个整数.推断数组中是否含有该整数. 思路 [算法系列之三十三]杨 ...
- 《剑指offer》 二维数组中的查找
本题目是<剑指offer>中的题目 二维数组中的查找 题目: 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个 ...
- 【Java】 剑指offer(3) 二维数组中的查找
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上 ...
- 《剑指Offer 1.二维数组中的查找》2019-03-25
剑指Offer 第一题 题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数 ...
- Go语言实现:【剑指offer】二维数组中的查找
该题目来源于牛客网<剑指offer>专题. 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一 ...
- 【剑指offer】二维数组中的查找
题目描述 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 注意点:要注意特殊 ...
- 剑指Offer 1. 二维数组中的查找 (数组)
题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数 ...
随机推荐
- Html空格字符代码:
Html空格字符代码: 为html空格字符代码,由“&+n+b+s+p+;”组成,记住最后一个分号不要忘记了.
- poj 1611(并查集)
http://poj.org/problem?id=1611 题意:有个学生感染病毒了,只要是和这个学生接触过的人都会感染,而和这些被感染者接触的人,也会被感染,现在给定你一些协会的人数,以及所在学生 ...
- (转)利用eclipse external tool 执行mvn jetty:run
一.如果这个工程是标准的maven-webapp那么基本上不用修改,直接运行jetty:run就可以执行. 但是有时候会报错说 [ERROR] No plugin found for prefix ' ...
- MySQL 通过idb文件恢复Innodb 数据【转】
昨晚收到一则求助,一个用户的本地数据库的重要数据由于误操作被删除,需要进行紧急恢复,用户的数据库日常并没有进行过任何备份,binlog也没有开启,所以从备份和binlog入手已经成为不可能,咨询了丁奇 ...
- 向数据库中全部表中增加一个字段的SQL
SELECT 'ALTER TABLE ' + NAME + ' ADD 字段名 int not null default 0' FROM sysobjects AS sWHERE s.[type] ...
- Python 开发轻量级爬虫01
Python 开发轻量级爬虫 (imooc总结01--课程目标) 课程目标:掌握开发轻量级爬虫 为什么说是轻量级的呢?因为一个复杂的爬虫需要考虑的问题场景非常多,比如有些网页需要用户登录了以后才能够访 ...
- 穹举,迭代,while循环。
所有循环 必要条件 : 初始条件(注意初始条件的位置) 循环条件 循环体 状态改变: 1.穷举 将所有可能性全部全部走一遍,使用IF筛选出满足的情况 使用循环语句 for ...
- 【python】类中的self
在python的类中,经常会写self,代表对象自己.如下例: #coding=utf-8 class Foo: def __init__(self, name): self.name = name ...
- 【python】判断字符串日期是否有效
来源: http://www.jb51.net/article/66014.htm http://www.runoob.com/python/att-time-strptime.html 用time模 ...
- 【XLL API 函数】xlfUnregister (Form 1)
此函数可以被 Excel 已经载入的 XLL 或 DLL 调用.它等效于宏表函数 UNREGISTER. xlfUnregister 有两种调用形式: 形式1:Unregister 单独的命令或函数 ...