| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1029 人关注过本帖
标题:求鞍点数!程序可以了,但是运行上还有一点小问题,请大家帮忙看看,谢过!
只看楼主 加入收藏
源本英明C
Rank: 3Rank: 3
来 自:日本
等 级:论坛游侠
帖 子:113
专家分:154
注 册:2010-5-14
结帖率:85.71%
收藏
 问题点数:0 回复次数:3 
求鞍点数!程序可以了,但是运行上还有一点小问题,请大家帮忙看看,谢过!
#define n 3
#define m 4
main()
{
 int i,j,a[n][m],maxi,minj;
 printf("\nplease input the array:\n");
 for(i=0;i<n;i++)
  for(j=0;j<m;j++)
 scanf("%d",&a[i][j]);

 printf("the array you have input is:\n");
 for(i=0;i<n;i++)
 {for(j=0;j<m;j++)
 printf("%4d",a[i][j]);printf("\n");}

 for(i=0;i<n;i++)
 {
 maxi=a[i][0];
 for(j=0;j<m;j++)
 if(a[i][j]>maxi)maxi=a[i][j];
 printf("max%d=%d  ",i,maxi);
 }

 for(j=0;j<m;j++)
 {
 minj=a[0][j];
 for(i=0;i<n;i++)
 if(a[i][j]<minj)minj=a[i][j];
 printf("min%d=%d  ",j,minj);
 }

 for(i=0;i<n;i++)
  for(j=0;j<m;j++)
   if(maxi==minj)printf("the an dian shi a[%d][%d]=%d\n",i,j,a[i][j]);
   printf(" meiyou andian!\n");
 getch();
}

问题如下:不管你怎么输入数据,不管有没有鞍点,程序运行结果始终没有鞍点(运行结果图如下图)。但是每行最大数,每列最小数都能正确输出,为什么if(maxi==minj)printf("the an dian shi a[%d][%d]=%d\n",i,j,a[i][j]);这句语句始终不被执行,还是我的逻辑出错了。请指教,不胜感激!
1.zip (7.26 KB)

搜索更多相关主题的帖子: 运行 鞍点 
2010-05-24 10:51
ouyangouyang
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:273
专家分:579
注 册:2009-10-8
收藏
得分:0 
程序不太好写,你没注意到的就是,你找到最大值还要找到最大值所对应的行列的数值,就是i和j,再进行判断,自己慢慢写吧,祝好运

多少恨, 昨夜梦魂中。 还似旧时游上苑, 车如流水马如龙; 花月正春风!
2010-05-24 11:42
lxqq1000
Rank: 2
等 级:论坛游民
帖 子:23
专家分:30
注 册:2010-5-19
收藏
得分:0 
哥哥 你那样定义 maxi    minj  不会随着i,j 变化,ok?所以结果也不正确
把maxi 和minj 改成数组max[i] 和min[j]应该就可以了
2010-05-24 13:39
源本英明C
Rank: 3Rank: 3
来 自:日本
等 级:论坛游侠
帖 子:113
专家分:154
注 册:2010-5-14
收藏
得分:0 
#define n 3
#define m 4
main()
{
 int i,j,a[n][m],max[n],min[m],flag=0;
 printf("\nplease input the array:\n");
 for(i=0;i<n;i++)
  for(j=0;j<m;j++)
 scanf("%d",&a[i][j]);

 printf("the array you have input is:\n");
 for(i=0;i<n;i++)
 {for(j=0;j<m;j++)
 printf("%4d",a[i][j]);printf("\n");}

 for(i=0;i<n;i++)
 {
 max[i]=a[i][0];
 for(j=0;j<m;j++)
 if(a[i][j]>max[i])max[i]=a[i][j];
 printf("max%d=%d  ",i,max[i]);
 }

 for(j=0;j<m;j++)
 {
 min[j]=a[0][j];
 for(i=0;i<n;i++)
 if(a[i][j]<min[j])min[j]=a[i][j];
 printf("min%d=%d  ",j,min[j]);
 }

 for(i=0;i<n;i++)
  for(j=0;j<m;j++)
   if(max[i]==min[j]){flag=1;
   printf("the an dian shi a[%d][%d]=%d\n",i,j,a[i][j]);  }
   if(flag==0)printf(" meiyou andian!\n");
 getch();
}这样就没问题了!

柔术:打败对手的最好方法就是心狠手辣,因为对手不会给你太多机会,如果他够厉害!
2010-05-25 11:00
快速回复:求鞍点数!程序可以了,但是运行上还有一点小问题,请大家帮忙看看,谢 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017744 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved