一本通网站1122题:计算鞍点

【题目描述】

给定一个5×5的矩阵,每行只有一个最大值,每列只有一个最小值,寻找这个矩阵的鞍点。鞍点指的是矩阵中的一个元素,它是所在行的最大值,并且是所在列的最小值。

例如:在下面的例子中(第4行第1列的元素就是鞍点,值为8 )。

c 复制代码
11 3 5 6 9
12 4 7 8 10
10 5 6 9 11
8 6 4 7 2
15 10 11 20 25

【输入】

输入包含一个5行5列的矩阵。

【输出】

如果存在鞍点,输出鞍点所在的行、列及其值,如果不存在,输出"not found"。

【输入样例】

bash 复制代码
11 3 5 6 9
12 4 7 8 10
10 5 6 9 11
8 6 4 7 2
15 10 11 20 25

【输出样例】

4 1 8

cpp 复制代码
#include<iostream>
using namespace std;
#include<string>
int main()
{
	ios::sync_with_stdio(false);
	cin.tie(nullptr); cout.tie(nullptr);
	//创建二维数组并输入数据
	int** arr = new int* [5];
	bool flag;
	for (int i = 0; i < 5; i++)
	{
		arr[i] = new int[5];
	}
	for (int i = 0; i < 5; i++)
	{
		for (int j = 0; j < 5; j++)
		{
			cin >> arr[i][j];
		}
	}
	for (int i = 0; i < 5; i++)
	{
		int max_num = arr[i][0];
		int k = 0;
		//遍历行,找出最大值及其列号
		for (int j = 0; j < 5; j++)
		{
			if (arr[i][j] > max_num) {
				max_num = arr[i][j];
				k = j;
			}
		}
		flag = true;
		//遍历列,判断该最大值是否为该列最小值
		for (int j = 0; j < 5; j++)
		{
			if (j == i) {
				continue;
			}
			if (arr[j][k] < arr[i][k]) {
				flag = false;
			}
		}
		//如果是则输出该鞍点的位置及值并结束程序
		if (flag)
		{
			cout << i + 1 << " " << k + 1 << " " << arr[i][k];
			break;
		}
	}
	//如果没有鞍点则输出"not found"
	if (!flag) {
		cout << "not found" << endl;
	}
}

题目大概的思路就是遍历每一行,找到这一行的最大值,然后记录所在的列,然后固定列,再去判断是不是这一列的最小值,然后用一个flag进行标记,最后也可以通过flag判断是否找到,如果没找到就输出not found。

我犯了两个错误:

  1. 在找最大值的时候,只顾着更新k,没有更新max_num,那么这个值就不一定是这一行的最大值
  2. 忘了判断在没有找到的时候打印not found。有时候还是需要多读几遍题目。不要漏掉了条件。
相关推荐
William Dawson13 小时前
2026软考中级系统集成项目管理工程师备考笔记
笔记·系统集成项目管理工程师
王老师青少年编程13 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮14 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
样例过了就是过了15 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
谭欣辰16 小时前
C++ 排列组合完整指南
开发语言·c++·算法
love530love16 小时前
精简版|Claude-HUD 插件介绍 + 一键安装教程
人工智能·windows·笔记
想成为优秀工程师的爸爸16 小时前
第三十篇技术笔记:郭大侠学UDS - 人有生老三千疾,望闻问切良方医
网络·笔记·网络协议·tcp/ip·信息与通信
橙子也要努力变强16 小时前
信号捕捉底层机制-机理篇2
linux·服务器·c++
盐焗鹌鹑蛋17 小时前
【C++】stack和queue类
c++
郝学胜-神的一滴18 小时前
罗德里格斯旋转公式(Rodrigues‘ Rotation Formula)完整推导
c++·unity·godot·图形渲染·three.js·unreal