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

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

分析如下图(也是测试用例):


上面例子:row = 4;col = 5;

IsExitNum()函数:值num在arr[4][5]中是否存在;

代码如下:

</pre><pre name="code" class="cpp"><span style="font-size:18px;">#include<iostream>
using namespace std;
bool IsExitNum(int arr[][5], int row,int col, int num)
{
	bool find = false;
	if (arr == NULL || (row < 0 && col < 0))
	{
		return find;
	}

	int _row = 0;
	int _col = col-1;

	while (_row < row && _col >= 0)
	{
		if (arr[_row][_col] > num)
		{
			--_col;
		}
		else if (arr[_row][_col] < num)
		{
			++_row;
		}
		else
		{
			find = true;
			return find;
		}
	}
	return find;
}
//测试用例:1.9,exit;
//			2.8,no exit;
//左上角	3.0, exit;
//右下角	4.29,exit;
//左下角	5.12,exit;
int main()
{
	int arr[4][5] = { { 0, 3, 7, 9, 13 }, { 2, 5, 11, 13, 17 }, { 9, 14, 15, 19, 21 }, { 12, 18, 20, 25, 29 } };
	bool ret = IsExitNum(arr, 4, 5, 9);
	if (ret)
	{
		cout << "9 exit" << endl;
	}
	else
	{
		cout << "9 no exit" << endl;
	}
	ret = IsExitNum(arr, 4, 5, 8);
	if (ret)
	{
		cout << "8 exit" << endl;
	}
	else
	{
		cout << "8 no exit" << endl;
	}
	ret = IsExitNum(arr, 4, 5, 0);
	if (ret)
	{
		cout << "0 exit" << endl;
	}
	else
	{
		cout << "0 no exit" << endl;
	}
	ret = IsExitNum(arr, 4, 5, 29);
	if (ret)
	{
		cout << "29 exit" << endl;
	}
	else
	{
		cout << "29 no exit" << endl;
	}
	ret = IsExitNum(arr, 4, 5, 12);
	if (ret)
	{
		cout << "12 exit" << endl;
	}
	else
	{
		cout << "12 no exit" << endl;
	}
	return 0;
}</span>



结果如下图所示:





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值