//找出二维数组中的鞍点,即该位置元素在该行最大,该列最小,也可能没有鞍点
#include <iostream>
#include <ctime>
using namespace std;
int main() {
::srand(::time(NULL));
int a[3][3];
for(int i=0;i<3;i++)
{
for(int j=0;j<3;j++)
{
a[i][j]=rand()%99+1;
cout<<a[i][j]<<'\t';
}
cout<<endl;
}
//找出每行最大值
int b[3];
for(int i=0;i<3;i++)
{
int max=0;
for(int j=0;j<3;j++)
{
if(a[i][j]>=max)
max=a[i][j];
}
b[i]=max;
}
//找出每列最小值
int c[3];
for(int j=0;j<3;j++)
{
int min=100;
for(int i=0;i<3;i++)
{
if(a[i][j]<=min)
min=a[i][j];
}
c[j]=min;
}
int counter=0;
for(int i=0;i<3;i++)
{
for(int j=0;j<3;j++)
{
if(b[i]==c[j])
{
cout<<"鞍点为:"<<b[i]<<endl;
counter++;
}
}
}
if(counter==0)
cout<<"无鞍点"<<endl;
return 0;
}
03-23
“相关推荐”对你有帮助么?
-
非常没帮助
-
没帮助
-
一般
-
有帮助
-
非常有帮助
提交