标题:请问我写的有什么问题吗,求解
只看楼主
Limetence
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2020-9-27
结帖率:50%
已结贴  问题点数:10 回复次数:2 
请问我写的有什么问题吗,求解

# include<stdio.h>
int main(){
    int n,m,h,x,y,o,p,g,f,q,w;
    int max[1000];
    int min[1000];
    scanf("%d%d",&n,&m);
    h=n*m;
    int shen[100000];
    while(h--){
     scanf("%d",&shen[n*m-h]);
    }
    o=m;
    p=n;
    while(m--){
        max[o-m]=shen[o-m];
        g=2*o-m;
        q=o-m;
        while(n-=1)
        {
        if(shen[g]>shen[q]){
        
        max[o-m]=shen[g];
        q=g;}
        g+=o;
    }}
    while(n--){
        min[p-n]=shen[p-n];
        g=p-n+1;
        w=p-n;
        while(m-=1){
        if(shen[g]<shen[w]){
        min[p-n]=shen[g];
        w=g;}
        g++;
}
    }
    while(m--){
        while(n--){
            if(max[m+1]==min[n+1])
            {x=m+1;
            y=n+1;
            }
        }
    }
    printf("(%d,%d)",x,y);
}
搜索更多相关主题的帖子: max int min scanf while 
2020-10-13 09:58
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:10 
变量太多,看不懂

程序代码:
#include <stdio.h>

int main( void )
{
    unsigned n, m;
    scanf( "%u%u", &n, &m );

    unsigned min_idxs_byrow[100]={0}, min_vals_byrow[100]={0};
    unsigned max_idxs_bycol[100]={0}, max_vals_bycol[100]={0};

    for( unsigned i=0; i!=n*m; ++i )
    {
        unsigned deepth;
        scanf( "%u", &deepth );

        if( ~0u-deepth > min_vals_byrow[i/m] )
        {
            min_idxs_byrow[i/m] = i%m;
            min_vals_byrow[i/m] = ~0u-deepth;
        }

        if( deepth > max_vals_bycol[i%m] )
        {
            max_idxs_bycol[i%m] = i/m;
            max_vals_bycol[i%m] = deepth;
        }
    }

    for( unsigned i=0; i!=n; ++i )
    {
        if( max_idxs_bycol[min_idxs_byrow[i]] == i )
            printf( "(%u,%u)\n", i+1, min_idxs_byrow[i]+1 );
    }
}
2020-10-13 11:34
Limetence
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2020-9-27
得分:0 
回复 2楼 rjsp
我化简了一下,你用的函数我都看不懂,难受
# include<stdio.h>
int main(){
    int n,m,h,x,y,o,p,g;//g是用来循环的,在南北是下一行然后一行一行加,东西一个一个加;o,p用来保存行数列数
    int max[100];
    int min[100];
    scanf("%d%d",&n,&m);
    h=n*m;
    int shen[10000];
    while(h--){
     scanf("%d",&shen[n*m-h]);
    }
    o=m;
    p=n;
    while(m--){
        max[o-m]=shen[o-m];
        g=2*o-m;
        while(n-=1)
        {
        if(shen[g]>max[o-m])
        max[o-m]=shen[g];
        g+=o;
    }}
    while(n--){
        min[p-n]=shen[p-n];
        g=p-n+1;
        while(m-=1){
        if(shen[g]<min[p-n])
        min[p-n]=shen[g];
        g++;
}
    }
    while(m--){
        while(n--){
            if(max[m+1]==min[n+1])
            {x=m+1;
            y=n+1;
            }
        }
    }
    printf("(%d,%d)",x,y);
}
2020-10-13 12:02



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-503453-1-1.html




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

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