| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 582 人关注过本帖
标题:ACM题目超时了
只看楼主 加入收藏
manesol
Rank: 1
等 级:新手上路
帖 子:53
专家分:0
注 册:2013-7-6
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:6 
ACM题目超时了
程序代码:
#include <STDIO.H>
#include <STRING.H>
typedef struct body 
{
    int hp;
    int str;
    int spd;
}bodystate;
bodystate getstate(char s[])
{
    bodystate c;
    int i,j;
    c.hp=0;
    c.str=1;
    c.spd=0;
    for(i=0;i<strlen(s);i++)
    {
        c.hp+=(83-s[i])*(83-s[i]);
    }
    c.hp=300-c.hp%97;
    for(i=0;i<strlen(s);i++)
    {
        c.str*=s[i];
    }
    c.str=22+c.str%79;
    for(i=0;i<strlen(s);i++)
        for(j=i+1;j<strlen(s);j++)
        {
            c.spd+=s[i]*s[j];
        }
    c.spd=c.spd%11;
    return c;
}
int main()
{
    int t;
    int time;
    char a[20],b[20];
    bodystate bodya,bodyb;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%s%s",a,b);
        bodya=getstate(a);
        bodyb=getstate(b);
        for(time=1;;time++)
        {
            if(bodya.hp<=0||bodyb.hp<=0)
                break;
            if(time%(20-bodya.spd)==0)
                bodyb.hp-=bodya.str;
            if(time%(20-bodyb.spd)==0)
                bodya.hp-=bodyb.str;
        }
        if(bodya.hp==0&&bodyb.hp==0)
            printf("tie\n");
        else if(bodya.hp<=0)
            printf("lose\n");
        else if(bodyb.hp<=0)
            printf("win\n");
    }
    return 0;
}

题目地址:http://172.19.141.56/OJ/Problem.aspx?id=91
求教啊!
搜索更多相关主题的帖子: color 
2013-07-28 16:18
manesol
Rank: 1
等 级:新手上路
帖 子:53
专家分:0
注 册:2013-7-6
收藏
得分:0 
2013-07-28 16:19
黑崎一心
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:53
专家分:158
注 册:2012-4-17
收藏
得分:0 
你的网址我是打不开,你就不能把题帖上来吗?
2013-07-28 16:27
manesol
Rank: 1
等 级:新手上路
帖 子:53
专家分:0
注 册:2013-7-6
收藏
得分:0 
回复 3楼 黑崎一心
http://hi.baidu.com/x80x86cj55555/item/aa05c72849108b65469962a3
2013-07-28 16:44
czz5242199
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:4
帖 子:660
专家分:2400
注 册:2011-10-26
收藏
得分:1 
这怎么会超时的,按规则算出双方的hp1,str1,spd1和hp2,str2,spd2

第一个人会在时间ceil(hp1/str2)*spd2的时间挂,第二个人会在ceil(hp2/str1)*spd1的时候挂,这步没必要模拟,能直接算出来
2013-07-28 18:34
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:19 
这题目本身规模很小,即使模拟应该也没什么问题。

但楼主的代码中STR的计算部分存在溢出风险,这样可能出现两个为负值的STR,这将导致PK的过程中两者的HP非旦不减反而增加,可不就超时了。

将那部分的取模运算放到循环里。

另外这句

        if(bodya.hp==0&&bodyb.hp==0)
            printf("tie\n");

中的==也该改成 <=

[ 本帖最后由 beyondyf 于 2013-7-28 18:57 编辑 ]

重剑无锋,大巧不工
2013-07-28 18:56
manesol
Rank: 1
等 级:新手上路
帖 子:53
专家分:0
注 册:2013-7-6
收藏
得分:0 
回复 6楼 beyondyf
大神就是大神!
2013-07-28 21:12
快速回复:ACM题目超时了
数据加载中...
 
   



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

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