Search a 2D Matrix

https://oj.leetcode.com/problems/search-a-2d-matrix/


1、题目要求:在一个m×n的矩阵matrix里面查找目标值target,如果查找成功返回true,否则返回false。

矩阵matrix的具有以下性质:

1)矩阵每行的元素从左到右递增排序;

2)每行的第一个元素比上一行的最后一个元素大;

例: 假设个定矩阵如下,给定目标值target= 3, 则返回true.

[
  [1,   3,  5,  7],
  [10, 11, 16, 20],
  [23, 30, 34, 50]
]


2、解题思路:用每行的第一个元素进行二分查找,确定target所在行,然后在所在行进行二分查找;


class Solution {
public:
    bool searchMatrix(vector<vector<int> > &matrix, int target) {
        int n= matrix.size();
        int left= 0, right= n-1, mid;
        //首先找到target所在的行
        while(left<=right)
        {
            mid= (left+right)/2;
            if(target>matrix[mid][0])
                left= mid+1;
            else if(target<matrix[mid][0])
                right= mid-1;
            else
                return true;
        }
        //如果target比最小值还小,说明查找失败
        if (left == 0)
		    return false;
		//此时left保持的就是target插入的位置(行标号),所以我们应该在left的上一行中查找target
        int row= left-1;
        left= 0, right= matrix[row].size()-1;
        while(left<=right)
        {
            mid= (left+right)/2;
            if(target>matrix[row][mid])
                left= mid+1;
            else if(target<matrix[row][mid])
                right= mid-1;
            else
                return true;
        }
        return false;
    }
};


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
transform:matrix是CSS3中的一个属性,它用于对元素进行变形操作。matrix()方法是transform属性中的一个函数,它可以通过一个矩阵来实现元素的旋转、缩放、倾斜和平移等变换效果。matrix()方法的参数由六个数字组成,分别代表矩阵的六个值,即a、b、c、d、e和f。通过调整这些值,可以实现不同的变形效果。例如,transform:matrix(1, 0, 0, 1, x, y)表示对元素进行平移操作,其水平偏移量为x,垂直偏移量为y。 通过理解transform中的matrix()矩阵方法,我们可以更深入地理解CSS3中的transform属性,并利用它来实现更丰富多样的元素变形效果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [CSS3矩阵理解———transform: matrix()改变元素运动的本质](https://blog.csdn.net/weixin_44309019/article/details/88722453)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [HTML 学习笔记 CSS3 (2D Matrix)](https://blog.csdn.net/ddiv24492/article/details/102234967)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值