| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1050 人关注过本帖
标题:高手帮忙看看 功能是求出一个在行里最大 列里最小的一个数
只看楼主 加入收藏
林月儿
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:湖南
等 级:版主
威 望:138
帖 子:2277
专家分:10647
注 册:2015-3-19
收藏
得分:0 
回复 10楼 rjsp
有道理,不过。。。感觉哪里不对劲

剑栈风樯各苦辛,别时冰雪到时春
2015-09-08 11:29
lowrie
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:81
专家分:138
注 册:2015-3-12
收藏
得分:3 
楼主的想法和我一样,先找行里最大的,再判断找到的是不是他所在列最大的。但楼主有几个地方写错了。
void fun(int (*a)[M])
{
    int i, j, k, max, min;
   
    for(i=0;i<N;i++)
    {
        max=a[i][0];
        for(j=1;j<M;j++)
        {
            if(max<a[i][j])  //这儿应该加一个{ }应为只有max<a[i][j]时 max=a[i][j] 和 k=j 都执行,但你这样写 k=j 每次都执行了。
                max=a[i][j];
                k=j;
        }
        min=a[0][k];
        for(i=1;i<N;i++)  //这儿不该用i,会和上边的i冲突,应该用j
        {
            if(min>a[i][k]) //判断错误,是找最小,不是最大
                min=a[i][k];
            
        }
        if(min==max)
            printf("find:a[%d][%d]=%d", i, k, a[i][k]);
        else
            printf("sorry it is not have it ");  //逻辑错误,每执行一行就会判断一次,这不科学,应该执行完了都没找到才打印这句话
    }
}



修改后代码如下,判断是否存在我是加了一个数T判断,T为1,表示存在,0表示不存在,默认为0。

#include <stdio.h>
#include <stdlib.h>
#define N 3
#define M 4

void fun(int (*a)[M])
{//N*M矩阵
    int i, j, k, max, min;
    int  T=0;
    for(i=0;i<N;i++)
    {
        
        max=a[i][0];
        for(j=1;j<M;j++)
        {
            if(max<a[i][j]){
                max=a[i][j];
                k=j;
            }
        }
        min=a[i][k];
        for(j=0;j<N;j++){
            if(a[j][k]<min)
            min=a[j][k];
            
        }
        if(min==max){
              printf("find:a[%d][%d]=%d", i, k, a[i][k]);
        T=1;
        }
    }
    if(T==0){
      printf("sorry it is not have it ");
    }

}

int main()
{
    int a[N][M], i, j;
    printf("enter number for array:\n");
    for(i=0;i<N;i++)
        for(j=0;j<M;j++)
            scanf("%d", &a[i][j]);
    printf("the arrayis :\n");
    for(i=0;i<N;i++)
    {
        for(j=0;j<M;j++)
            printf("%3d", a[i][j]);   
        printf("\n");
    }
    fun(a);
    system("pause");
    return 1;
}
2015-09-08 11:36
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9031
专家分:54061
注 册:2011-1-18
收藏
得分:3 
以下是引用林月儿在2015-9-8 11:29:56的发言:

有道理,不过。。。感觉哪里不对劲
假如存在这么个鞍点,那么你的算法就是对的。
但有可能不存在这个鞍点,因此你的算法求出这个点后,还得验证一下其是否为鞍点。
比如
 2 3
 4 2
2015-09-08 12:03
林月儿
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:湖南
等 级:版主
威 望:138
帖 子:2277
专家分:10647
注 册:2015-3-19
收藏
得分:3 
回复 13楼 rjsp
我就是这个意思,实际情况好像。。。额,算了智商余额不足

剑栈风樯各苦辛,别时冰雪到时春
2015-09-08 12:21
露营地
Rank: 2
来 自:湛江
等 级:论坛游民
帖 子:150
专家分:23
注 册:2015-6-27
收藏
得分:0 
回复 10楼 rjsp
恩恩 你说的是对的  不过林月儿 的代码  也能实现  不过就是不知道会不会遇到什么问题  遇到问题我在提问   
说的那里不对 别见怪哈 @林月儿

不要不要的。。。
2015-09-08 13:07
露营地
Rank: 2
来 自:湛江
等 级:论坛游民
帖 子:150
专家分:23
注 册:2015-6-27
收藏
得分:0 
回复 14楼 林月儿
不过也能实现 现在


不要不要的。。。
2015-09-08 13:08
露营地
Rank: 2
来 自:湛江
等 级:论坛游民
帖 子:150
专家分:23
注 册:2015-6-27
收藏
得分:0 
回复 12楼 lowrie
恩恩   我先看看哈

不要不要的。。。
2015-09-08 13:09
林月儿
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:湖南
等 级:版主
威 望:138
帖 子:2277
专家分:10647
注 册:2015-3-19
收藏
得分:0 
回复 15楼 露营地
你以为是qq啊,还@我去java逛逛了有问题再说吧。。。

剑栈风樯各苦辛,别时冰雪到时春
2015-09-08 14:15
露营地
Rank: 2
来 自:湛江
等 级:论坛游民
帖 子:150
专家分:23
注 册:2015-6-27
收藏
得分:0 
回复 18楼 林月儿
因为我回复的不是你啊 后面那句才是和你说的嘛 所以@一下咯  哈哈

不要不要的。。。
2015-09-08 14:46
露营地
Rank: 2
来 自:湛江
等 级:论坛游民
帖 子:150
专家分:23
注 册:2015-6-27
收藏
得分:0 
回复 12楼 lowrie
if(min>a[i][k]) 和if(a[i][k]>min)  不一样么

不要不要的。。。
2015-09-08 15:27
快速回复:高手帮忙看看 功能是求出一个在行里最大 列里最小的一个数
数据加载中...
 
   



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

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