[java]

/**

* 递归分治算法学习之二维二分查找

* @author Sking

问题描述:

存在一个二维数组T[m][n],每一行元素从左到右递增,

每一列元素从上到下递增,现在需要查找元素X(必在二维

数组中)在数组中的位置,要求时间复杂度不超过m+n.

*/

package 递归分治;

public class BinarySearchInArray {

/**

* 二维二分搜索的实现

* @param array 待查找的二维数组

* @param value  待查找的元素

* @param m1 数组左上角横坐标

* @param n1  数组左上角纵坐标

* @param m2 数组右下角横坐标

* @param n2  数组右下角纵坐标

* @return 待查找元素在二维数组中的位置索引,存在长度为2的数组中

*                  未找到则返回null。

*/

int[] binarySearchInArray(int[][] array, int value, int m1, int n1, int m2,

int n2) {

//(beginX,beginY)表示数组左上角坐标

int beginX = m1, beginY = n1;

//(endX,endY)表示数组右下角坐标

int endX = m2, endY = n2;

int[] leftResult = new int[2];//递归查找得到的左下角搜索结果

int[] rightResult = new int[2];//递归查找得到的右上角搜索结果

int i = (m1 + m2) / 2, j = (n1 + n2) / 2;//不是对角阵

if (value < array[m1][n1] || value > array[m2][n2])

return null;

if (value == array[m1][n1])

return new int[] { m1, n1 };

if (value == array[m2][n2])

return new int[] { m2, n2 };

//子矩阵对角线方向上的二分查找,确定递归子矩阵

while ((i != m1 || j != n1) && (i != m2 || j != n2)) {

if (value == array[i][j])

return new int[] { i, j };

else if (value < array[i][j]) {

m2 = i;

n2 = j;

i = (i + m1) / 2;

j = (j + n1) / 2;

} else {

m1 = i;

n1 = j;

i = (i + m2) / 2;

j = (j + n2) / 2;

}

}//如果找到则返回,否则对左下角和右上角矩阵进行递归查找

if (i < endX)//右上角递归查找

leftResult = binarySearchInArray(array, value, i + 1, beginY, endX,j);

if (j < endY)//左下角递归查找 
            rightResult = binarySearchInArray(array, value, beginX, j + 1, i,endY);

if (leftResult != null)

return leftResult;

if (rightResult != null)

return rightResult;

return null;

}

}

递归分治算法之二维数组二分查找(Java版本)的更多相关文章

  1. JavaScript 递归法排列组合二维数组2

    <html> <head> <title>二维数组排列组合</title> </head> <body> <div id= ...

  2. JavaScript 递归法排列组合二维数组

    <html> <head> <title>二维数组排列组合</title> </head> <body> <div id= ...

  3. ACM_二维数组的查找

    二维数组的查找 Time Limit: 2000/1000ms (Java/Others) Problem Description: 给定一个n*m的二维数组,保证a[i][j] < a[i+1 ...

  4. 剑指Offer01之二维数组中查找目标数

    剑指Offer之二维数组中查找目标数 题目描述 ​ 在一个二维数组中(每个一维数组的长度相等),每一行都是从左到右递增的顺序排序,每一列都是从上到下递增的顺序排序,输入这样一个二维数组和一个整数,判断 ...

  5. 《剑指Offer》算法题——二维数组查找

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

  6. 【2048小游戏】——原生js爬坑之遍历算法显示二维数组内容

    引言:做2048小游戏会将横纵方向的数字内容,存储在一个二维数组中,要将这个二维数组中的内容显示在页面上,就一定要用遍历算法来实现了. 一.二维数组存储    首先考虑用二维数组存储所有行数,列数   ...

  7. 牛客网剑指offer 二维数组的查找

    题目描述 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 解题思路 该题有很多种 ...

  8. 剑指 offer set 1 二维数组中查找

    总结 1. 二维数组搜索题遇到两个了, 一个是 Leetcode 上 search in 2D matrix. 那道题比较简单, 因为下一行的所有元素大于上一行的. 这道题对二维矩阵的要求比较松, 起 ...

  9. word search(二维数组中查找单词(匹配字符串))

    Given a 2D board and a word, find if the word exists in the grid. The word can be constructed from l ...

随机推荐

  1. Jmeter+maven+Jenkins构建云性能测试平台(mark 推荐)

    转自:http://www.cnblogs.com/victorcai0922/archive/2012/06/20/2555502.html Jmeter+maven+Jenkins构建云性能测试平 ...

  2. Javascript判断Crontab表达式是否合法

    这段时间在做Quartz任务调度,使用的Crontab表达式实现的.Crontab由前端页面输入,作为参数穿入后台. 虽然Quartz具有校验Crontab表达式的方法,如下: boolean cro ...

  3. OnPreRender事件常见用法

    protected override void OnPreRender(EventArgs e) 1) 加入脚本 protected override void OnPreRender(EventAr ...

  4. MM bound 与 Jensen's inequality

    MM bound 与 Jensen's inequality 简森不等式 在使用最大似然估计方法求解模型最优解的时候,如果使用梯度下降(GD or SGD)或者梯度上升(GA or SGA),可能收敛 ...

  5. Alias Method for Sampling 采样方法

    [Alias Method for Sampling]原理 对于处理离散分布的随机变量的取样问题,Alias Method for Sampling 是一种很高效的方式. 在初始好之后,每次取样的复杂 ...

  6. 【转】DSL

    DSL DSL 时不时地会成为一个话题,所以今天想专门说一下. DSL 也就是 Domain Specific Language 的简称,是指为某些特定领域(domain)设计的专用语言.举个例子,L ...

  7. tableView的用法具体解释

    1 tableView的类型   1.1 UITableViewStylePlain  没有区头 不显区头     向上滑动区头不会移动到屏幕外面 ' 1.2 UITableViewStyleGrou ...

  8. cucumber java从入门到精通(3)简单实现及断言

    cucumber java从入门到精通(3)简单实现及断言 上一节里我们定义了step的java代码实现文件,step就是测试步骤及断言的集合,我们先定义出来,以后可以驱动开发以及在持续集成时重用. ...

  9. Mac OS X 下多个JDK版本的切换小技巧

    如果在系统中安装了多个Java JDK 版本,可能会根据项目或编译环境的不同来回切换,下面有两种非常方便的方法供大家选择. 我的机器上有 Java 7 和 Java 8,大家根据自己的 JDK 版本自 ...

  10. Linux版迅雷(Xware)安装配置方法

    Linux版迅雷下载请见:Xware下载 解压下载的压缩包 核对MD5或SHA1校验值 解压得到以下三个文件 安装文件 在/usr/local/下创建thunder文件夹,将上面的三个文件放入,然后运 ...