08-2. 求矩阵的局部极大值(15)

本文详细探讨了如何在给定的M行N列整数矩阵中寻找并输出局部极大值及其位置,包括输入输出格式及具体实现算法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

08-2. 求矩阵的局部极大值(15)

时间限制
400 ms
内存限制
32000 kB
代码长度限制
8000 B
判题程序
Standard
作者
徐镜春(浙江大学)

给定M行N列的整数矩阵A,如果A的非边界元素A[i][j]大于相邻的上下左右4个元素,那么就称元素A[i][j]是矩阵的局部极大值。本题要求给定矩阵的全部局部极大值及其所在的位置。

输入格式:

输入在第1行中给出矩阵A的行数M和列数N(3<=M,N<=20);最后M行,每行给出A在该行的N个元素的值。数字间以空格分隔。

输出格式:

每行按照“元素值 行号 列号”的格式输出一个局部极大值,其中行、列编号从1开始。要求按照行号递增输出;若同行有超过1个局部极大值,则该行按列号递增输出。若没有局部极大值,则输出“None 总行数 总列数”。

输入样例1:
4 5
1 1 1 1 1
1 3 9 3 1
1 5 3 5 1
1 1 1 1 1
输出样例1:
9 2 3
5 3 2
5 3 4
输入样例2:
3 5
1 1 1 1 1
9 3 9 9 1
1 5 3 5 1
输出样例2:
None 3 5
#include <stdio.h>
int main()
{
	int r,c,x,i,j,flag;
	scanf("%d %d",&r,&c);
	//printf("%d %d",r,c);
	int array[r][c];
	int max[r];
	for(i=0;i<r;i++)
	{
		for(j=0; j<c;j++)
		{
			scanf("%d",&array[i][j]);			
		}
	}
//	for(i=0;i<r;i++)
//	{	
//		for(j=0; j<c;j++)
//		{
//			printf("%d ",array[i][j]);				
//		}
//		printf("\n");
//	}
	flag=0;
	for(i=1;i<r-1;i++)
	{
		for(j=1; j<c-1;j++)
		{
			if(array[i][j]>array[i][j-1] && array[i][j]>array[i][j+1] 
			&& array[i][j]>array[i-1][j] && array[i][j]>array[i+1][j])
			{
				flag=1;//改变标记状态 
				printf("%d %d %d\n",array[i][j],i+1,j+1);
			}					
		}
		if(!flag)
		printf("None %d %d",r,c);
	}
	return 0;
} 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值