#include <stdio.h>
int main()
{
int x[4][4],i,j,max,t,y,min;
for(i=1;i<=4;i++)
{
for(j=1;j<=4;j++)
scanf("%d",&x[i][j]);
}
for(t=1;t<=4;t++)//进行4次总循环
{
for(i=t;i<=t;i++)//一行一行的算
{
for(j=1;j<=4;j++)
{
if(x[i][j]>x[i][j+1])
{
max=x[i][j];y=j;//求出每一行的最大值 然后在将其所在的列记录下来
}
}
}
for(i=1;i<=4;i++)
{
if(x[i][y]<x[i][y])//用记录下来的y 去求那一列的最小值
{
min=x[i][y];
}
}
if(max=min)//当最小值等于最大值时得到结果
{
printf("%d",max);
}
}
return 0;
}
完犊子了 是求数组鞍点的 我自己先写了一个程序 感觉逻辑是对的但是运行是错的 想求大家看一看 哪里出问题了
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 南七灵 2022-01-05 11:12关注
if(x[i][j]>x[i][j+1])
会越界#include <stdio.h> int main() { int x[4][4], i, j, max, t, y, min; for (i = 0; i < 4; i++) { for (j = 0; j < 4; j++) scanf("%d", &x[i][j]); } for (i = 0; i < 4; i++) { max = x[i][0]; for (j = 0; j < 4; j++) //一行一行的算 { if (x[i][j] > max) { max = x[i][j]; y = j; //求出每一行的最大值 然后在将其所在的列记录下来 } } min = x[0][y]; for (t = 0; t < 4; t++) { if (x[t][y] < min) //用记录下来的y 去求那一列的最小值 { min = x[t][y]; } } if (max == min) //当最小值等于最大值时得到结果 { printf("%d ", max); } } return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥100 求数学坐标画圆以及直线的算法
- ¥100 c语言,请帮蒟蒻写一个题的范例作参考
- ¥15 名为“Product”的列已属于此 DataTable
- ¥15 安卓adb backup备份应用数据失败
- ¥15 eclipse运行项目时遇到的问题
- ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
- ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
- ¥15 自己瞎改改,结果现在又运行不了了
- ¥15 链式存储应该如何解决
- ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站