鱼C论坛

 找回密码
 立即注册
查看: 1030|回复: 3

[已解决]c语言鞍点问题

[复制链接]
发表于 2020-11-23 22:54:43 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
求求大佬救救孩子,寻找鞍点问题,意思是一个二维数组中,如果一个数在其所在行中最大,但在其所在列最小,则为鞍点。要求输出该数,以及其所在的行、列,最难的要求是重复也算,
例如: 1   2    2
           1   3    3
           1    4   4   
输出要求为:   2   第一行  第二列
                      2   第一行  第三列
下面是我的代码,无法解决重复问题,求大佬救救孩子


#include<stdio.h>
//寻找鞍点,以3*3数组为例
#define M 3
#define N 3
int main()
{
        int a[M][N];       //初始二维数组
        int i,j,k;         //循环计数
        int m,temp;        //筛选中间量
        printf("输入数组数值(%d个):\n",M*N);
        for(i=0;i<M;++i)
                for(j=0;j<N;++j)
                        scanf("%d",&a[i][j]);
        //校检输入是否符合预期
        printf("校检如下:\n");
        for(i=0;i<M;++i)
        {
                printf("第%d行:",i+1);
                for(j=0;j<N;++j)
                {
                        printf("  %d  ",a[i][j]);
                }
                printf("\n");
        }
        //筛选鞍点
        for(i=0;i<M;i++)      //每行
        {
                m = a[i][0];      
                for(j=0;j<N;++j)
                {
                        if(a[i][j]>m)
                        {
                                m = a[i][j];
                                temp = j;
                        }
                }

                for(k=0;k<M;++k)
                {
                        if(m>a[k][temp])
                        {
                                printf("第%d行无鞍点\n",i);
                                break;
                        }
                }
                if(k==M)
                {
                        printf("鞍点: %d 第%d行,第%d列\n",m,i+1,temp+1);
                }
        }
        return 0;

}
最佳答案
2020-11-24 10:47:23
此题目是谭浩强《C语言程序设计》的课后习题。下面的程序,是我学习时写的,本不想翻旧帐,两天了,没有人回答你,程序还是给你吧(你要的是 3 x 3 ,将定义中的 M、N 改为 3 即可):
  1. #include <stdio.h>
  2. #define M 10    //最大接收M行N列的数组,这里是10*10,可修改。
  3. #define N 10
  4. int main()
  5. {
  6.         int a[M][N], b[N];
  7.         int i, j, k, s, max, min, count = 0;
  8.         //下面用来接收数组的输入
  9.         printf("输入数组元素:");

  10.         for (i = 0;i < M;i++)         // 输入数组
  11.         {
  12.                 for (j = 0;j < N;j++)
  13.                 {
  14.                         scanf("%d", &a[i][j]);
  15.         }
  16.     }
  17.     // 打印数组
  18.     for (i = 0;i < M;i++)
  19.     {
  20.             for (j = 0;j < N;j++)
  21.             {
  22.                         printf("%5d", a[i][j]);
  23.             }
  24.                 printf("\n");
  25.     }
  26.     //查找判断鞍点
  27.     for (j = 0;j < M;j++)
  28.         {
  29.             max = a[j][0];
  30.                 for (i = 0;i < N;i++)    // 找第j行最大值
  31.                         if (a[j][i] > max)
  32.                                 max = a[j][i];

  33.                 s = 0;
  34.             for (i = 0;i < N;i++)     //将最大值所在的列存入数组b[s]中
  35.             if (a[j][i] = max)
  36.         {
  37.                     b[s] = i;
  38.                         s++;                  //s的值就是最大值的个数
  39.         }

  40.                 min = max;

  41.         for (i = 0;i < s;i++)     //有几个最大值循环判断几次
  42.         {
  43.                         for (k = 0;k < M;k++)//判断这个行最大值是不是列最小
  44.                                 if (min > a[k][b[i]])
  45.                                         break;

  46.                         if (k == M)              //输出,count为鞍点个数
  47.                                 printf("鞍点为第%d行第%d列的%d\n", j + 1, b[i] + 1, a[j][b[i]]);
  48.                         count++;
  49.         }
  50.     }
  51. }
复制代码

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-11-24 10:47:23 | 显示全部楼层    本楼为最佳答案   
此题目是谭浩强《C语言程序设计》的课后习题。下面的程序,是我学习时写的,本不想翻旧帐,两天了,没有人回答你,程序还是给你吧(你要的是 3 x 3 ,将定义中的 M、N 改为 3 即可):
  1. #include <stdio.h>
  2. #define M 10    //最大接收M行N列的数组,这里是10*10,可修改。
  3. #define N 10
  4. int main()
  5. {
  6.         int a[M][N], b[N];
  7.         int i, j, k, s, max, min, count = 0;
  8.         //下面用来接收数组的输入
  9.         printf("输入数组元素:");

  10.         for (i = 0;i < M;i++)         // 输入数组
  11.         {
  12.                 for (j = 0;j < N;j++)
  13.                 {
  14.                         scanf("%d", &a[i][j]);
  15.         }
  16.     }
  17.     // 打印数组
  18.     for (i = 0;i < M;i++)
  19.     {
  20.             for (j = 0;j < N;j++)
  21.             {
  22.                         printf("%5d", a[i][j]);
  23.             }
  24.                 printf("\n");
  25.     }
  26.     //查找判断鞍点
  27.     for (j = 0;j < M;j++)
  28.         {
  29.             max = a[j][0];
  30.                 for (i = 0;i < N;i++)    // 找第j行最大值
  31.                         if (a[j][i] > max)
  32.                                 max = a[j][i];

  33.                 s = 0;
  34.             for (i = 0;i < N;i++)     //将最大值所在的列存入数组b[s]中
  35.             if (a[j][i] = max)
  36.         {
  37.                     b[s] = i;
  38.                         s++;                  //s的值就是最大值的个数
  39.         }

  40.                 min = max;

  41.         for (i = 0;i < s;i++)     //有几个最大值循环判断几次
  42.         {
  43.                         for (k = 0;k < M;k++)//判断这个行最大值是不是列最小
  44.                                 if (min > a[k][b[i]])
  45.                                         break;

  46.                         if (k == M)              //输出,count为鞍点个数
  47.                                 printf("鞍点为第%d行第%d列的%d\n", j + 1, b[i] + 1, a[j][b[i]]);
  48.                         count++;
  49.         }
  50.     }
  51. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-11-25 19:31:23 | 显示全部楼层
风过无痕1989 发表于 2020-11-24 10:47
此题目是谭浩强《C语言程序设计》的课后习题。下面的程序,是我学习时写的,本不想翻旧帐,两天了,没有人 ...

谢谢您
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-25 21:18:30 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-20 07:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表