#include <stdio.h>
#define N 4
#define M 5
int main()
{
int i,j,k,a[N][M],max,maxj,flag;
printf("Please input matrix:
");
for(i=0;i<N;i++)
for(j=0;j<M;j++)
scanf("%d",&a[i][j]);//输入数组
for(i=0;i<N;i++)//从每行中挑选
{
max=a[i][0];
for(j=0;j<M;j++)//找出第i行最大的数
if(a[i][j]>max)
{
max=a[i][j];
maxj=j;
}
flag=1;//纵向比较是否为最小
for(k=0;k<N;k++)
if(max>a[k][maxj])//纵向还有比它小的值 不是鞍点 退出此次循环 执行下一行
{
flag=0;
continue;
}
if(flag)//max为此列最小值
{
printf("a[%d][%d]=%d",i,maxj,max);
break;
}
}
if(!flag)
printf("It is not exists!
");
return 0;
}