CSU 1507 超大型LED显示屏

135 篇文章 0 订阅
50 篇文章 0 订阅

Description

Input

输入包含不超过100组数据。每组数据第一行为"START hh:mm:ss",表示比赛开始时刻为hh:mm:ss。最后一行为"END hh:mm:ss",即比赛结束时刻。二者之间至少会有一个SCORE信息,格式为"SCORE hh:mm:ss team score",其中team要么是"home"(主场)要么是"guest"(客场), score表示得分,为1,2或者3。这些信息保证按照时间从早到晚的顺序排列,且任意两条SCORE信息的时刻均不相同。比赛开始时间不会早于9:00,结束时间不会晚于同一天的21:00。注意,如果比赛开始时间为09:00:00,结束时间为09:00:01,比赛长度为1秒钟,而不是2秒钟。

Output

对于每组数据,输出测试点编号和总耗电量。

Sample Input

START 09:00:00
SCORE 09:01:05 home 2
SCORE 09:10:07 guest 3
END 09:15:00
START 09:00:00
SCORE 10:00:00 home 1
SCORE 11:00:00 home 1
SCORE 12:00:00 home 1
SCORE 13:00:00 home 1
SCORE 14:00:00 home 1
SCORE 15:00:00 home 1
SCORE 16:00:00 home 1
SCORE 17:00:00 home 1
SCORE 18:00:00 home 1
SCORE 19:00:00 home 1
SCORE 20:00:00 home 1
END 21:00:00

Sample Output

Case 1: 9672
Case 2: 478800

#include <stdio.h>
#include <string.h>

int k[10]={6,2,5,5,4,5,6,3,7,6};

int ff(int n)
{
    int sum=0;
    if(n==0)
        return 6;
    while(n)
    {
        int temp=n%10;
        n/=10;
        sum+=k[temp];
    }
    return sum;
}
int tt(int d,int e,int f,int a,int b,int c)
{
    if(c>f)
    {
        f+=60;
        e--;
    }
    if(b>e)
    {
        e+=60;
        d--;
    }
    return 3600*(d-a)+60*(e-b)+f-c;
}
int main()
{
    int i,j,f1,f2;
    char a[10],b[10];
    int sh,sm,ss,h,m,s,num,h1,h2,m1,m2,s1,s2,t=1;
    long long sum1,sum2;
    while(~scanf("%s %d:%d:%d",a,&sh,&sm,&ss))
    {
        sum1=sum2=0;
        h1=h2=sh;
        m1=m2=sm;
        s1=s2=ss;
        f1=f2=0;
        if(strcmp(a,"START")==0)
        {
            while(~scanf("%s %d:%d:%d",a,&h,&m,&s))
            {
                if(a[0]=='E')
                    break;

                scanf("%s %d",b,&num);
                if(strcmp(a,"SCORE")==0)
                {
                    if(strcmp(b,"home")==0)
                    {
                        if(sum1==0)
                        {
                            sum1+=6*tt(h,m,s,sh,sm,ss);
                            f1=num;
                            h1=h,m1=m,s1=s;
                        }
                        else
                        {
                            sum1+=ff(f1)*tt(h,m,s,h1,m1,s1);
                            f1+=num;
                            h1=h,m1=m,s1=s;

                        }
                    }
                    else
                    {
                        if(sum2==0)
                        {
                            sum2+=6*(tt(h,m,s,sh,sm,ss));
                            f2=num;
                            h2=h,m2=m,s2=s;
                         //   printf("%lld %d %d\n",sum2,ff(f2),tt(h,m,s,sh,sm,ss));
                        }
                        else
                        {
                            sum2+=ff(f2)*tt(h,m,s,h2,m2,s2);
                            f2+=num;
                            h2=h,m2=m,s2=s;
                        }
                    }
                }
            }
            sum1+=ff(f1)*(tt(h,m,s,h1,m1,s1));
            sum2+=ff(f2)*(tt(h,m,s,h2,m2,s2));
            printf("Case %d: %lld\n",t++,sum1+sum2);
        }
    }
    return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值