鱼C论坛

 找回密码
 立即注册
查看: 1923|回复: 2

暗点

[复制链接]
发表于 2023-12-7 19:54:54 | 显示全部楼层
鞍点是一个矩阵中的特定元素,它是其所在行中的最大数,同时也是其所在列中的最小数。

为了找出矩阵的鞍点,我们需要进行以下步骤:

  • 1. 遍历矩阵的每一行,找出每一行的最大值及其列索引。
  • 2. 使用上一步得到的列索引,检查对应列中的元素是否也是该列的最小值。
  • 3. 如果一个元素同时满足这两个条件,那么它就是鞍点。
  • 4. 如果没有元素满足这些条件,输出“NO”。

下面是使用C语言解决这个问题的代码示例:

  1. #include <stdio.h>
  2. #define ROWS 3
  3. #define COLS 4

  4. int main() {
  5.     int matrix[ROWS][COLS];
  6.     int maxInRow, minInCol, saddlePointFound = 0;
  7.     int i, j, k;

  8.     // 输入矩阵
  9.     printf("请输入一个 %d*%d 的矩阵:\n", ROWS, COLS);
  10.     for (i = 0; i < ROWS; i++) {
  11.         for (j = 0; j < COLS; j++) {
  12.             scanf("%d", &matrix[i][j]);
  13.         }
  14.     }

  15.     // 寻找鞍点
  16.     for (i = 0; i < ROWS; i++) {
  17.         maxInRow = matrix[i][0];
  18.         int maxColIndex = 0;
  19.         // 找到每行的最大值
  20.         for (j = 1; j < COLS; j++) {
  21.             if (matrix[i][j] > maxInRow) {
  22.                 maxInRow = matrix[i][j];
  23.                 maxColIndex = j;
  24.             }
  25.         }

  26.         // 检查找到的最大值是否也是所在列的最小值
  27.         minInCol = maxInRow;
  28.         for (k = 0; k < ROWS; k++) {
  29.             if (matrix[k][maxColIndex] < minInCol) {
  30.                 minInCol = matrix[k][maxColIndex];
  31.             }
  32.         }

  33.         // 如果同时是行中最大和列中最小
  34.         if (minInCol == maxInRow) {
  35.             printf("鞍点是: %d 在 (%d, %d)\n", maxInRow, i, maxColIndex);
  36.             saddlePointFound = 1;
  37.             break;
  38.         }
  39.     }

  40.     if (!saddlePointFound) {
  41.         printf("NO\n");
  42.     }

  43.     return 0;
  44. }
复制代码


这个程序会提示用户输入一个3x4的矩阵,然后它会查找并输出矩阵的鞍点。如果没有鞍点,它将输出“NO”。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-9 03:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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