// Offer-P44-4.cpp: 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include<vector>
#include<iostream>
using namespace std;
class Solution
{
public:
int target;
vector<vector<int>> array;
bool Find(int target, vector<vector<int>> array)
{
if (array.empty()) return false;//非空判定
int rowcount = array.size();//行数
int colcount = array[0].size();//列数
int i, j;
for (i = rowcount - 1, j = 0; i >= 0 && j < colcount;)//从左下角开始遍历
{
if (target == array[i][j])
{
return true;
}
if (target < array[i][j])//目标数比当前数小,从上一行继续查找
{
--i;
continue;
}
if (target > array[i][j])//目标数比当前数大,从下一列开始查找
{
++j;
continue;
}
}
return false;
}
};
int main()
{
vector<vector<int>> array1 = { {1,2,8,9},{2,4,9,12},{4,7,10,13},{6,8,11,15} };
vector<vector<int>> array2 = {};
int i1 = 7;
int i2 = 16;
int i3 = 0;
int i4 = 5;
Solution sol;
if (sol.Find(i1, array1))
{
cout << "true1" << endl;
}
else
cout << "false1" << endl;
if (sol.Find(i2, array1))
{
cout << "true2" << endl;
}
else
cout << "false2" << endl;
if (sol.Find(i3, array1))
{
cout << "true3" << endl;
}
else
cout << "false3" << endl;
if (sol.Find(i4, array1))
{
cout << "true4" << endl;
}
else
cout << "false4" << endl;
if (sol.Find(i4, array2))
{
cout << "true5" << endl;
}
else
cout << "false5" << endl;
return 0;
}
在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
最新推荐文章于 2021-05-10 12:52:38 发布