题目:
给定一个5*5的矩阵,每行只有一个最大值,每列只有一个最小值,寻找这个矩阵的鞍点。
鞍点指的是矩阵中的一个元素,它是所在行的最大值,并且是所在列的最小值。
例如:在下面的例子中(第4行第1列的元素就是鞍点,值为8 )。
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
ps:这个题吧,我朋友错了好几次,我帮他调完后发现了一些问题,应该需要说一下
题解:
循环每行,在每行中找到一个最大值,记下列数,对本列进行循环,最后符合条件输出即可
经验教训:
想好再写!!!!!!!
代码:
#include <bits/stdc++.h>
using namespace std;
int main(){
int a[6][6],l=0,sum=5;
for(int i=1;i<=5;i++){
for(int j=1;j<=5;j++){
scanf("%d",&a[i][j]);
}
}
for(int i=1;i<=5;i++){
int hmax=-10000,lmin,flag=0;
for(int j=1;j<=5;j++){
if(a[i][j]>hmax){
hmax=a[i][j];
lmin=a[i][j];
l=j;
//printf("%d %d\n",i,hmax);
}
}
for(int k=1;k<=5;k++){
if(a[k][l]<lmin){
flag=1;
//printf("%d %d 1\n",lmin,l);
break;
}
}
if(flag==0){
printf("%d %d %d\n",i,l,hmax);
sum--;
}
}
if(sum==5){
printf("not found");
}
return 0;
}
太水了
本文介绍了一个算法问题,即在一个特定的5*5矩阵中寻找鞍点的方法。鞍点是指该元素在其所在行中最大而在其所在列中最小。文章提供了一段C++代码实现,并分享了调试过程中的经验和教训。
3633

被折叠的 条评论
为什么被折叠?



