标题:请教一个C语言问题
只看楼主
ma815841356
Rank: 1
等 级:新手上路
帖 子:34
专家分:0
注 册:2015-5-3
结帖率:100%
已结贴  问题点数:10 回复次数:2 
请教一个C语言问题
这是题目内容



我在本地有测试过几组数据,没发现有错误,但提交到网上返回的是wrong answer,想请问一下是不是我代码中有考虑不全的地方,还望指教,谢谢

 以下是本人的代码:

#include<stdio.h>

 int n[61][61][61];

 int main()
 {
     int i,t,w;

     int c,a,b;

     int max,sum=0;

     scanf("%d%d%d",&a,&b,&c);

     for(i=1; i<=c; i++)
         for(t=1; t<=a; t++)
             for(w=1; w<=b; w++)
                 scanf("%d",&n[i][t][w]);

     sum=0;

     for(t=1; t<=a; t++)//上
        for(w=1; w<=b; w++)
             sum=sum+n[1][t][w];
     max=sum;

     sum=0;

     for(i=1; i<=c; i++)//后
        for(w=1; w<=b; w++)
             sum=sum+n[i][1][w];
     if(sum>max)
         max=sum;

     sum=0;

     for(i=1; i<=c; i++)//右
        for(t=1; t<=a; t++)
             sum=sum+n[i][t][b];
     if(sum>max)
         max=sum;

     sum=0;

     for(i=1; i<=c; i++)//左
        for(t=1; t<=a; t++)
             sum=sum+n[i][t][1];
     if(sum>max)
         max=sum;

     sum=0;

     for(i=1; i<=c; i++)//前
        for(w=1; w<=b; w++)
             sum=sum+n[i][a][w];
     if(sum>max)
         max=sum;

     sum=0;

     for(t=1; t<=a; t++)//下
        for(w=1; w<=b; w++)
             sum=sum+n[c][t][w];
     if(sum>max)
         max=sum;

     printf("%d\n",max);

     return 0;
 }
搜索更多相关主题的帖子: 网上 wrong C语言 include 
2015-05-05 13:08
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:10 
你只考虑了6个外表面,没有切入到内部的计算

根据你本身的算法,随手写段代码,只保证编译通过,未测试
程序代码:
#include <stdio.h>
#include <limits.h>

int main( void )
{
    int cube[60][60][60];

    unsigned a, b, c;
    scanf( "%u%u%u", &a, &b, &c );

    for( unsigned ic=0; ic<c; ++ic )
        for( unsigned ia=0; ia<a; ++ia )
            for( unsigned ib=0; ib<b; ++ib )
                scanf( "%d", &cube[ic][ia][ib] );

    int maxsum = INT_MIN;

    // 垂直于“高”
    for( unsigned ic=0; ic<c; ++ic )
    {
        int sum = 0;
        for( unsigned ia=0; ia<a; ++ia )
            for( unsigned ib=0; ib<b; ++ib )
                sum += cube[ic][ia][ib];

        if( sum > maxsum )
            maxsum = sum;
    }

    // 垂直于“长”
    for( unsigned ia=0; ia<a; ++ia )
    {
        int sum = 0;
        for( unsigned ic=0; ic<c; ++ic )
            for( unsigned ib=0; ib<b; ++ib )
                sum += cube[ic][ia][ib];

        if( sum > maxsum )
            maxsum = sum;
    }

    // 垂直于“宽”
    for( unsigned ib=0; ib<b; ++ib )
    {
        int sum = 0;
        for( unsigned ic=0; ic<c; ++ic )
            for( unsigned ia=0; ia<a; ++ia )
                sum += cube[ic][ia][ib];

        if( sum > maxsum )
            maxsum = sum;
    }

    printf( "%d\n", maxsum );

    return 0;
}


其实数据没必要保存,随手写段代码,只保证编译通过,未测试
程序代码:
#include <stdio.h>
#include <limits.h>

int main( void )
{
    int sum[60+60+60] = { 0 };

    unsigned a, b, c;
    scanf( "%u%u%u", &a, &b, &c );

    for( unsigned ic=0; ic<c; ++ic )
        for( unsigned ia=0; ia<a; ++ia )
            for( unsigned ib=0; ib<b; ++ib )
            {
                int v;
                scanf( "%d", &v );
                sum[ic] += v;
                sum[c+ia] += v;
                sum[c+a+ib] += v;
            }

    int maxsum = INT_MIN;
    for( unsigned i=0; i!=c+a+b; ++i )
        if( maxsum < sum[i] )
            maxsum = sum[i];

    printf( "%d\n", maxsum );

    return 0;
}

2015-05-05 15:51
ma815841356
Rank: 1
等 级:新手上路
帖 子:34
专家分:0
注 册:2015-5-3
得分:0 
回复 2楼 rjsp
你说的很对,我没能看清题目,没有考虑里面切面的情况,谢谢你的指点,thanks
2015-05-05 22:12



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




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

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