输出二维数组的鞍点(行最大,列最小)

//找二维数组鞍点
# include<stdio.h>
float a[10][10];
int maxrow[10];
int mincol[10];
int n;
int main()
{
    printf("请输入n:");
    scanf("%d",&n);
    printf("请输入%d阶矩阵:",n);
    for(int i=0;i<n;i++)
        for(int j=0;j<n;j++)
            scanf("%f",&a[i][j]);
    for(i=0;i<n;i++)
    {
        for(int j=0;j<n;j++)
            printf("%7.2f",a[i][j]);
        printf("\n");
    }

    for(i=0;i<n;i++)
    {
        float max=a[i][0];
        maxrow[i]=0;
        for(int j=1;j<n;j++)
        {
            if(a[i][j]>max)
            {
                max=a[i][j];
                maxrow[i]=j;
            }
        }
    }

    for(int j=0;i<n;i++)
    {
        float min=a[0][j];
        mincol[j]=0;
        for(i=1;i<n;i++)
        {
            if(a[i][j]<min)
            {
                min=a[i][j];
                mincol[j]=i;
            }
        }
    }

    for(i=0;i<n;i++)
        for(int j=0;j<n;j++)
        {
            if(i==mincol[j]&&j==maxrow[i])
                printf("a[%d][%d]=%7.2f\n",i,j,a[i][j]);
        }
    return 0;
}

运行结果:

 

posted @ 2020-03-06 17:15  kakusan  阅读(758)  评论(0编辑  收藏  举报