二维数组的鞍点

二维数组的鞍点:行中最大,列中最小
 	int a[3][3]={{5,12,3},{9,10,3},{8,21,8}};
    int i,j,k,has_point=0;//has_point为二维数组中是否有鞍点的标记
    for(i=0; i<3; i++)
    {
        for(j=0; j<3; j++)
            printf("%3d ",a[i][j]);
        printf("\n");
    }
    printf("\n");
    for(i=0; i<3; i++)
    {
        int max_row_index=0,flag=1;
        //找出第i行中最大元素的下标:max_row_index
        for(j=1; j<3; j++)
        {
            if(a[i][j]>a[i][max_row_index])
                max_row_index=j;
        }
        //找出该行最大元素后,判断其是否是该列中最小的元素
        for(k=0; k<3; k++)
        {
            if(a[k][max_row_index]<a[i][max_row_index])
                flag=0;
        }
        //是,则输出该鞍点,并刷新标志has_point
        if(flag)
        {
            printf("鞍点:%d\n",a[i][max_row_index]);
            has_point=1;
        }
    }
    if(!has_point)
        printf("没有鞍点\n");

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值