递归分治算法之二维数组二分查找(Java版本)
[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版本)的更多相关文章
- JavaScript 递归法排列组合二维数组2
<html> <head> <title>二维数组排列组合</title> </head> <body> <div id= ...
- JavaScript 递归法排列组合二维数组
<html> <head> <title>二维数组排列组合</title> </head> <body> <div id= ...
- ACM_二维数组的查找
二维数组的查找 Time Limit: 2000/1000ms (Java/Others) Problem Description: 给定一个n*m的二维数组,保证a[i][j] < a[i+1 ...
- 剑指Offer01之二维数组中查找目标数
剑指Offer之二维数组中查找目标数 题目描述 在一个二维数组中(每个一维数组的长度相等),每一行都是从左到右递增的顺序排序,每一列都是从上到下递增的顺序排序,输入这样一个二维数组和一个整数,判断 ...
- 《剑指Offer》算法题——二维数组查找
题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. class Solutio ...
- 【2048小游戏】——原生js爬坑之遍历算法显示二维数组内容
引言:做2048小游戏会将横纵方向的数字内容,存储在一个二维数组中,要将这个二维数组中的内容显示在页面上,就一定要用遍历算法来实现了. 一.二维数组存储 首先考虑用二维数组存储所有行数,列数 ...
- 牛客网剑指offer 二维数组的查找
题目描述 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 解题思路 该题有很多种 ...
- 剑指 offer set 1 二维数组中查找
总结 1. 二维数组搜索题遇到两个了, 一个是 Leetcode 上 search in 2D matrix. 那道题比较简单, 因为下一行的所有元素大于上一行的. 这道题对二维矩阵的要求比较松, 起 ...
- word search(二维数组中查找单词(匹配字符串))
Given a 2D board and a word, find if the word exists in the grid. The word can be constructed from l ...
随机推荐
- JetBrains全系列在线激活中心pycharm
题记:有能力还是建议购买正版授权! 01.pycharm下载 https://www.jetbrains.com/pycharm/download/ https://download.jetbrai ...
- java服务端微信小程序支付
发布时间:2018-10-05 技术:springboot+maven 概述 java微信小程序demo支付只需配置支付一下参数即可运行 详细 代码下载:http://www.demodash ...
- TL 重构
import dependencies.*;import org.apache.commons.lang3.ArrayUtils;import org.apache.commons.lang3.Str ...
- Linux-TCP之深入浅出send和recv
内容摘自:TCP之深入浅出send和recv.再次深入理解TCP网络编程中的send和recv 建议阅读时参考:Unix环境高级编程-TCP.UDP缓冲区 概念 先明确一个概念:每个TCP socke ...
- git学习笔记(三)—— 远程仓库
一.gitHub&&SSH Key 为git仓库提供托管服务的,所以注册一个github账号,就可以免费获得git远程仓库. 本地Git仓库和GitHub仓库之间的传输是通过SSH加密 ...
- k8s实战之Service
一.概述 为了适应快速的业务需求,微服务架构已经逐渐成为主流,微服务架构的应用需要有非常好的服务编排支持,k8s中的核心要素Service便提供了一套简化的服务代理和发现机制,天然适应微服务架构,任何 ...
- 【Linux】字符转换命令join
join 看字面上的意义 (加入/参加) 就可以知道,他是在处理两个文件之间的数据,而且,主要是在处理『两个文件当中,有 "相同数据" 的那一行,才将他加在一起』的意思.我们利用底 ...
- Transparent Huge Pages
在RHEL6中,透明大页功能是默认开启的. 开启该选项后,内核会尽可能地尝试分配大页,如果mmap区域是2mb,那么每个linux进程都会分配到2mb大小的页.如果大页不够用了(比如物理内存不够了), ...
- spring-cloud/spring-cloud-sleuth github 项目 mark
97 Star639 Fork335 spring-cloud/spring-cloud-sleuth CodeIssues 5Pull requests 1Projects 0WikiInsigh ...
- 基于Docker搭建LNMP环境(转)
关于什么是docker,建议大家先上网查查有关的用法.如果您不了解,在这篇文章中,您可以简单的理解为他是一个轻量级的虚拟机. 一.docker安装mysql 首先,我们从仓库拉取一个MySql的镜像 ...