矩阵元素查找

题目描述
已知int一个有序矩阵mat,同时给定矩阵的大小n和m以及需要查找的元素x,且矩阵的行和列都是从小到大有序的。设计查找算法返回所查找元素的二元数组,代表该元素的行号和列号(均从零开始)。保证元素互异。

示例1
输入 [[1,2,3],[4,5,6]],2,3,6
返回值 [1,2]

该题目解题思路与二维数组的查找类似,都是选取二维数组右上角开始,如果小于右上角元素则 j --,大于则 i ++ ,相等就将 该元素的 横纵坐标放到vector中。

class Solution {
public:
    vector<int> findElement(vector<vector<int> > mat, int n, int m, int x) {
        // write code here
        int i = 0,j = m-1;
        vector<int> res;
        if(n==0 || m==0) return res;
        while(i<n && j>=0)
        {
            if(mat[i][j]>x) j--;
            else if(mat[i][j]<x) i++;
            else 
            {
                res.push_back(i);
                res.push_back(j);
                break;
            }
        }
        return res;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值