O-超大型LED显示屏
发布日期:2021-08-21 13:17:45 浏览次数:47 分类:技术文章

本文共 2074 字,大约阅读时间需要 6 分钟。

这里写图片描述

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
#include
#include
#include
using namespace std;const int d[10]={
6,2,5,5,4,5,6,3,7,6};struct node{ int h,m,s; node(int h=0,int m=0,int s=0):h(h),m(m),s(s){}}pre,now;int tran(const node &pre,const node &now){ int p = pre.s + pre.m*60 + pre.h*3600; return (now.s + now.m*60 + now.h *3600 - p);}struct Time{ int past_score,sum; node pre; Time(){past_score = sum = 0;} void updata(const int &score,const node &now){ char ch[30]; int tmp = 0; sprintf(ch,"%d",past_score); int len = strlen(ch); for(int i=0;i
> str){ Time A,B; int score; scanf("%d:%d:%d",&now.h,&now.m,&now.s); A.Init(now),B.Init(now); while(cin >> str){ scanf("%d:%d:%d",&now.h,&now.m,&now.s); if(str == "END"){ print_ans(A,B,now); break; }else{ cin >> str >> score; if(str == "home")A.updata(score,now); else B.updata(score,now); } } }}

 

转载于:https://www.cnblogs.com/Pretty9/p/7347688.html

转载地址:https://blog.csdn.net/weixin_33720078/article/details/93661224 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:很想回家,想念从前......
下一篇:学习一下HTTP

发表评论

最新留言

路过按个爪印,很不错,赞一个!
[***.219.124.196]2024年04月19日 12时15分02秒