您的位置:首页 > 其它

“盛大游戏杯”第15届上海大学程序设计联赛夏季赛暨上海高校金马五校赛-神无月排位赛

2017-07-10 14:44 357 查看


神无月排位赛(“盛大游戏杯”第15届上海大学程序设计联赛夏季赛暨上海高校金马五校赛(重现赛))

发布时间: 2017年7月9日 18:30   最后更新: 2017年7月9日 21:18   时间限制: 1000ms   内存限制: 128M

描述

《神无月》作为盛大游戏2017年的全新原创大作,其开发团队在自研实力强大的传世工作室基础之上,还有美树本晴彦等日本一线知名画师及日本游戏音乐大师崎元仁加盟参与制作。目前正在不限号内测中,有很多玩家进入到神无月的世界中。
在神无月中,有着玩家之间切磋的排位赛,其段位主要分为五大段位,从低到高依次为:新兵、菁英、战将、统帅、王者。每个玩家只有从新兵段位慢慢努力,一点点晋级才能到达王者段位。成为一个王者是每一个玩家的追求和心愿。



假设神无月的段位系统如下:
从低到高的段位依次简记为:D、C、B、A、S。玩家打排位赛,每胜利1局增加10分,输1局扣除5分。每一个段位都需要积分,累计100分才可以进入晋级赛,晋级赛采用三局两胜制(3局中达到2局胜利就晋级成功,有2局失败就算晋级
4000
失败, 连胜或连败两局,第三局不需要打了)。晋级成功后,成为下一个段位,积分变为0,重新开始算分;如果晋级失败,则积分变为60,重新开始算分。为方便计算,如果该玩家一直输,积分降为0后,不再降分,也不会掉段位。
大圣同学最近对神无月非常喜欢,一直在努力成为王者。他从新兵0分开始打排位赛(刚开始处在段位D),他告诉你最近若干场比赛的最后胜利情况,请你写个算法猜猜他现在所处的段位。当段位到达S时,段位将不再提高。

输入

有若干组数据。

每组的第一行为一个N(0<N<500),表示有N场比赛数据。

第二行有N个数字,每个数字之间有空格隔开,每个数字代表每场比赛的输赢情况,1表示赢,0表示输。

注意:当第n场比赛结束时,若大圣同学正处于晋级赛,并且还无法决定晋级成功或失败,那么可以忽略这场晋级赛

输出

对于每组比赛数据,输出最后所处的段位的一个英文字符(D、C、B、A、S这五个段位中的一个)。

样例输入1 复制
15
1 1 1 1 1 1 1 1 1 1 1 1 1 0 1
30
1 1 1 1 1 1 1 1 1 1 1 1 1 0 1 1 1 0 1 1 1 1 1 1 1 1 0 1 1 1


样例输出1
C
B


选择语言
水题
注意下题目细节
代码:
#include<stdio.h>

#include<string.h>

int a[510];

int main()

{

    int N=0;

    while(scanf("%d",&N)!=EOF)

    {

        memset(a,0,sizeof(a));

        int i,j;

        int sum=0;

        int count=0;

        int flag=0;

        for(i=0;i<N;i++)

        {

            scanf("%d",&a[i]);

        }

        for(i=0;i<N;i++)

        {

            if(a[i]==1)

                sum+=10;

            else //if(a[i]==0)

                sum-=5;

            if(sum>=100&&count!=4&&i+1<N)

            {

                if(a[i+1]+a[i+2]==2)

                {

                  sum=0;

                  count++;

                  i+=2;

                }

                else if(a[i+1]+a[i+2]==0)

                {

                    sum=60;

                    i+=2;

                }

                else if(a[i+1]+a[i+2]==1)

                {

                    if(a[i+3]==1)

                    {

                        sum=0;

                       count++;

                       i+=3;

                    }

                    else

                    {

                       sum=60;

                       i+=3;

                    }

                }

            }

            if(count==4)

            {

               flag=1;

               continue;

            }

            if(sum<=0)

            {

                sum=0;

            }

        }

        if(flag==1)

            printf("S\n");

        else

        {

            printf("%c\n",'D'-count);

        }

    }

    return 0;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐