二维数组查找(单行,单列有序二维数组查找)

二维数组中的查找

http://www.nowcoder.com/questionTerminal/abc3fe2ce8e146608e868a70efebf62e

/*
二维数组有序数组查找
不断缩小查找数组的范围。
从后面最大开始查找是否有等于target的值,如果大于target,则该位置下面和右边的所有数都大于target,不满足。
找到到第一个小于target的位置时,下方数组都可能存在,则换得到下一行。
*/
class Solution {
public:
    bool Find(int target, vector<vector<int> > array){
        int m=array.size(),n=array[0].size(),row=0;
        while(n&&row<m){
            if(target==array[row][n-1])return true;
            if(target<array[row][n-1])n--;
            else row++;
        }
        return false;
    }
};
全部评论

相关推荐

Java转测开第一人:这种就是饼 把应届当廉价劳动力用完然后丢掉
你觉得今年秋招难吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务