网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

有序二维数组中的查找

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

目前创新互联建站已为上千多家的企业提供了网站建设、域名、虚拟主机成都网站托管、企业网站设计、太仆寺网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

思路:首先看到这样一个题目我们先分析题目,把二维数组在纸上画成一个矩形。列如:1 2 8 9

                                       2 4 9 12  

                                       4 7 10 13     

                                       6 8 11 15

然后从数组中选取一个数字7。分三种情况来分析查找过程:当选取的数字跟要查找的数字相等时,结束。当选取的数字小于要查找的数字时,要查找的数字应该在当前选取数字的右边或者下边。当选取的数字大于要查找的数字时,要查找的数字应该在当前选取数字的左边或者上边。

这种情况有可能会出现重叠区域,代码不太容易实现。

我们可以换种角度思考,减少查找的范围,我们每次都以右上角的数字作为标准进行比较,当查找的数字小于右上角的数字时,剔除该数字所在的这一列。当查找的数字大于右上角的数字时,剔除该数字所在的这一行。慢慢的减少查找的范围,最终找到该数字。

代码实现如下:

#include
using namespace std;
bool Find(int (*arr)[4],int rows,int cols,int num)
{
	if(arr!=NULL && rows>0 && cols>0)
	{
		int row=0;
		int col=cols-1;
		while(row=0)
		{
			if(arr[row][col]==num)
				return true;
			else if(arr[row][col]>num)
				col--;
			else
				row++;
		}
		return false;
	}
}
int main()
{
	int arr[][4]={1,2,8,9,2,4,9,12,4,7,10,13,6,8,11,15};
	bool ret=Find(arr,4,4,7);
	cout<            
            
                        
文章名称:有序二维数组中的查找
分享路径:http://bjjierui.cn/article/posjhe.html

其他资讯