【1】二维数组中的查找

【1】二维数组中的查找

  • 时间限制:1秒空间限制:32768K
  • 本题知识点: 查找

题目描述

在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
输入描述:
array: 待查找的二维数组
target:查找的数字

输出描述:
查找到返回true,查找不到返回false

[ 牛客网题目链接 ]

vs2010调试代码块

#include <iostream>
#include <vector>
using namespace std;


bool IsFound( vector< vector< int > > array, int target )
{
    //cout<<Array.size()<<endl;
    //cout<<Array[0].size()<<endl;
    int row=array.size();  //获取数组的行列
    int col=array[0].size();

    int PRow=0;  //初始搜索位置
    int PCol=col-1;

    for(; PRow<row && PCol>=0; ) //列不能左,行不能下时停止
    {
        //cout<<array[PRow][PCol]<<endl;
        if( target<array[PRow][PCol] )
            PCol--;
        else if( target>array[PRow][PCol] )
            PRow++;
        else
            return 1;
    }
    return 0;
}

//int a0[3][4]={
//  {1, 2, 3, 4},
//  {5, 6, 7, 8},
//  {9, 10, 11, 12}    
//};
int a0[1][1]={{1}};
int aim=1; 

int main()
{
    int M=1, N=1;
    vector< vector< int > > a(M, vector<int>(N));

    for(int i=0; i<M; i++) //将数组内容转到容器中
    {
        for(int j=0; j<N; j++)
        {
            a[i][j]=a0[i][j];
        }
    }

    for(int i=0; i<M; i++)  //输出容器中元素
    {
        for(int j=0; j<N; j++)
            cout<<a[i][j]<<"\t";
        cout<<endl;
    }

    cout<<IsFound( a, aim);

}

牛客网提交的代码块

class Solution {
public:
    bool Find(vector<vector<int> > array,int target) {
            //cout<<Array.size()<<endl;
    //cout<<Array[0].size()<<endl;
    int row=array.size();  //获取数组的行列
    int col=array[0].size();

    int PRow=0;  //初始搜索位置
    int PCol=col-1;

    for(; PRow<row && PCol>=0; ) //列不能左,行不能下时停止
    {
        //cout<<array[PRow][PCol]<<endl;
        if( target<array[PRow][PCol] )
            PCol--;
        else if( target>array[PRow][PCol] )
            PRow++;
        else
            return 1;
    }
    return 0;

    }
};

代码通过图片
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值