Search a 2D Matrix——两度二分查找
Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the following properties:
- Integers in each row are sorted from left to right.
- The first integer of each row is greater than the last integer of the previous row.
For example,
Consider the following matrix:
[
[1, 3, 5, 7],
[10, 11, 16, 20],
[23, 30, 34, 50]
]
Given target = 3, return true.
这题很简单
思路:二分法确定target可能在第几行出现。再用二分法在该行确定target可能出现的位置。时间复杂度O(logn+logm)
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int m=matrix.size();
        int n=matrix[].size();
        int l=,r=m-,mid;
        if(target>matrix[m-][n-]||target<matrix[][])
            return false;
        while(l<r)
        {
            mid=l+(r-l)/;
            if(target==matrix[mid][n-])
                return true;
            else if(target<matrix[mid][n-])
                r=mid;
            else
                l=mid+;
        }
        int index=r;
        l=;
        r=n-;
        while(l<=r)
        {
            mid=l+(r-l)/;
            if(target==matrix[index][mid])
                return true;
            else if(target<matrix[index][mid])
                r=mid-;
            else
                l=mid+;
        }
        return false;
    }
};
Search a 2D Matrix——两度二分查找的更多相关文章
- [LeetCode] 74 Search a 2D Matrix(二分查找)
		二分查找 1.二分查找的时间复杂度分析: 二分查找每次排除掉一半不合适的值,所以对于n个元素的情况来说: 一次二分剩下:n/2 两次:n/4 m次:n/(2^m) 最坏情况是排除到最后一个值之后得到结 ... 
- LeetCode  Search a 2D Matrix(二分查找)
		题意: 有一个矩阵,每行都有序,每行接在上一行尾后仍然有序.在此矩阵中查找是否存在某个数target. 思路: 这相当于用一个指针连续扫二维数组一样,一直p++就能到最后一个元素了.由于用vector ... 
- [LeetCode] Search a 2D Matrix  搜索一个二维矩阵
		Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ... 
- 54. Search a 2D Matrix   &&   Climbing Stairs (Easy)
		Search a 2D Matrix Write an efficient algorithm that searches for a value in an m x n matrix. This m ... 
- [Leetcode Week13]Search a 2D Matrix
		Search a 2D Matrix 题解 原创文章,拒绝转载 题目来源:https://leetcode.com/problems/search-a-2d-matrix/description/ D ... 
- [LeetCode] 74. Search a 2D Matrix  搜索一个二维矩阵
		Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ... 
- leetcode 74. Search a 2D Matrix 、240. Search a 2D Matrix II
		74. Search a 2D Matrix 整个二维数组是有序排列的,可以把这个想象成一个有序的一维数组,然后用二分找中间值就好了. 这个时候需要将全部的长度转换为相应的坐标,/col获得x坐标,% ... 
- 28. Search a 2D Matrix 【easy】
		28. Search a 2D Matrix [easy] Write an efficient algorithm that searches for a value in an mx n matr ... 
- Leetcode之二分法专题-240. 搜索二维矩阵 II(Search a 2D Matrix II)
		Leetcode之二分法专题-240. 搜索二维矩阵 II(Search a 2D Matrix II) 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target.该矩阵 ... 
随机推荐
- nodejs获取文件信息,判断是文件或目录
			var stat = fs.statSync(filename); console.log(stat) 输出 { dev: 0, ino: 0, mode: 33206, nlink: 1, uid: ... 
- shell中的颜色显示
			By francis_hao Sep 30,2017 图片来自参考[1] 其中,"033"是八进制数,其对应的asciima也就是ESC.后面的颜色格式为:[背景 ... 
- MyEclipse下项目的包层次结构调整
			新电脑安装完MyEclipse,导入项目后发现MyEclipse下项目的包层次结构变成了Flat,平面模式,这种模式感觉特别不好, 不能清晰地显示出项目的包层次结构.这样,显示出的包的结构不够明显,我 ... 
- PowerDesigner12.5下载汉化及破解
			一.下载: 在网上直接输入PowerDesigner12.5下载,很多地方都可以下载成功. 二.汉化: 直接将解压的汉化文件复制[覆盖]到安装目录即可. 三.破解[稍微费事一点]: 1.安装完成后,修 ... 
- LoaderManager与CursorLoader用法
			一.基本概念 1.LoaderManager LoaderManager用来负责管理与Activity或者Fragment联系起来的一个或多个Loaders对象. 每个Activity或者Fragme ... 
- 2017 济南综合班 Day 7
			a 两个指针L.R R开始指向恰好[R,n]有不超过k个逆序对的地方 随着L的右移,R指针只会右移 逆序对有2部分 1.L左侧与其他位置形成的逆序对 2.R右侧与其他位置形成的逆序对 用树状数组分别 ... 
- 「模板」 线段树——区间乘 && 区间加 && 区间求和
			「模板」 线段树--区间乘 && 区间加 && 区间求和 原来的代码太恶心了,重贴一遍. #include <cstdio> int n,m; long l ... 
- No cached version of .....  available for offline mode.
			I had same error...Please Uncheck the offline work in Settings. File => Settings => Build, Exe ... 
- bzoj 1914: [Usaco2010 OPen]Triangle Counting 数三角形——极角排序
			Description 在一只大灰狼偷偷潜入Farmer Don的牛群被群牛发现后,贝西现在不得不履行着她站岗的职责.从她的守卫塔向下瞭望简直就是一件烦透了的事情.她决定做一些开发智力的小练习,防止她 ... 
- 【NOIP】提高组2016 蚯蚓
			[题目链接]Universal Online Judge [题解]本题最大的特点在于从大到小切以及切分规则一致,都是切成px和x-px. 由这两个特点很容易得到结论,后切的蚯蚓得到的px一定比先切的蚯 ... 
