杨氏矩阵中查找数

杨氏矩阵中查找数

介绍:一组数从左向右递增,从上相下递增。
方法:在矩阵中以右上角作为起点,则矩阵向左数据变小,向下数据变大,我们只需要控制横纵下标,便可以找到此数,
int Find(int a[][3], int x, int y, int n)
{
	int i = 0;
	int j = y - 1;
	while (i < x&&j >= 0)
	{
		if (n < a[i][j])//矩阵的数大于查找的数,我们向左找
			j--;//列数减一
		else if (n > a[i][j])//矩阵的数大于查找的数,我们向下找
			x++;//行数加1
		else
			return 1;//找到返回1
	}
	return -1;//未找到-1
}
void main()
{
	int a[][3] = { 1,2,3,4,5,6,6,7,8,9 ,13,15};/二维数组根据列数,自动确定行数,每3个一行。列数必须有,行数可以没有
	int x = 10;
	int res=Find(a, 4, 3, x);
	if (res>0)
		printf("Founded\n");
	else
		printf("Unfounded\n");
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值