【2012年中山纪念中学信息学竞赛初一选拔赛一】纪中篮球联赛(b)

【2012年中山纪念中学信息学竞赛初一选拔赛一】纪中篮球联赛(b)

(File IO): input:b.in output:b.out 时间限制: 1000 ms 空间限制: 262144 KB

【题目描述】
纪中有自己的篮球联赛,简称JBA,比赛共48分钟,需要注意的是比赛没有罚篮,没有3分球,所以每次得分一定是得2分。当比赛结束时,各项技术统计就应该出炉。作为记分员的你负责记录每一次的得分情况,现在你突然对两支队伍领先持续的总时间感兴趣。

【输入】
第一行包含一个整数N(1<=N<=100),接下来N行,每行描述一次得分。
每个得分描述包含得分的队伍编号1或2,还包含得分时刻MM:SS(MM表示分,范围为[00,47],SS表示秒,范围为[00,59]),队伍和时刻之间用一个空格隔开。

【输出】
输出两行,分别表示队伍1和队伍2领先的时间。时间用MM:SS表示。

【样例输入】
样例输入1
1
1 20:00
样例输入2
3
1 01:10
2 21:10
2 31:30
样例输入3
5
1 01:10
1 02:20
2 45:30
2 46:40
2 47:50

【样例输出】
样例输出1
28:00
00:00
样例输出2
20:00
16:30
样例输出3
45:30
00:10

【思路】
按每次得分来模拟,注意模拟结束后记得再判断一次进位。

【AC代码】

#include<iostream>
#include<cstdio>
#include<bits/stdc++.h>
using namespace std;
int n,p[1001],a[1001],b[1001];
int fa=0,fb=0;
int a1,a2,b1,b2;
int ansa1=0,ansa2=0,ansb1=0,ansb2=0;
int main(){
	freopen("b.in","r",stdin);
	freopen("b.out","w",stdout);
	cin>>n;
	char ch;
	for(int i=1;i<=n;i++){
		cin>>p[i]>>a[i];
		cin>>ch;
		cin>>b[i];
	}
	int flag=0;
	for(int i=1;i<=n;i++){
		if(p[i]==1){
			fa++;
		}else if(p[i]==2){
			fb++;
		}
		if(flag==1){
			if(fb>fa){
				flag=2;
				ansa1+=(a[i]-a1);
				ansa2+=(b[i]-a2);
				b1=a[i];
				b2=b[i];
				a1=0;
				a2=0;
			}else if(fb==fa){
				flag=0;
				ansa1+=(a[i]-a1);
				ansa2+=(b[i]-a2);
				a1=0;
				a2=0;
			}
		}else if(flag==2){
			if(fa>fb){
				flag=1;
				ansb1+=(a[i]-b1);
				ansb2+=(b[i]-b2);
				b1=0;
				b2=0;
				a1=a[i];
				a2=b[i];
			}else if(fb==fa){
				flag=0;
				ansb1+=(a[i]-b1);
				ansb2+=(b[i]-b2);
				b1=0;
				b2=0;
			}
		}else if(flag==0){
			if(fa>fb){
				a1=a[i];
				a2=b[i];
			}else{
				b1=a[i];
				b2=b[i];
			}
		}
		if(fa>fb)flag=1;
		else if(fb>fa)flag=2;
		else flag=0;
		ansa1+=(ansa2/60);
		ansb1+=(ansb2/60);
		ansa2=ansa2%60;
		ansb2=ansb2%60;
	}
	if(a1||a2){
		ansa1+=(47-a1);
		ansa2+=(60-a2);
	}
	if(b1||b2){
		ansb1+=(47-b1);
		ansb2+=(60-b2);
	}
	ansa1+=(ansa2/60);
	ansb1+=(ansb2/60);
	ansa2=ansa2%60;
	ansb2=ansb2%60;
	if(ansb2<0){
		ansb1--;
		ansb2=60+ansb2;
	}
	if(ansa2<0){
		ansa1--;
		ansa2=60+ansa2;
	}
	printf("%02d:%02d\n",ansa1,ansa2);
	printf("%02d:%02d",ansb1,ansb2);
	fclose(stdin);
	fclose(stdout);
	return 0;
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
庐阳区2022信息学竞赛试题工作日(day)将是一项具有挑战性和丰富内容的学术竞赛活动。信息学竞赛是一项旨在考察参赛者在计算机科学、算法设计和编程技能等方面的能力的竞赛活动。 在庐阳区2022信息学竞赛试题中,参赛者将面临各种具有难度的问题,这些问题往往涉及到计算机科学的基本概念和算法设计。参赛者需要独立思考和解决这些问题,表现出对编程语言和算法的掌握能力。 试题中可能包括编写程序解决问题的任务,参赛者需要用合适的编程语言编写程序,并根据题目需求输出正确的结果。这个过程要求参赛者在理解问题、设计算法和实现代码等方面具备扎实的计算机科学基础知识和编程技巧。 庐阳区2022信息学竞赛试题将在工作日进行。参赛者需要在规定的时间内完成试题,并提交自己的答案。竞赛的评判标准将根据参赛者题目的正确性、程序的效率和代码的质量等方面进行评估。 信息学竞赛的目的是激发学生对计算机科学的兴趣,提高他们的编程和问题解决能力。通过参与竞赛,学生们可以拓宽视野、增加知识储备,并提高自己在计算机科学领域的竞争力。 参与庐阳区2022信息学竞赛试题的选手们将面临一项充满挑战的学术竞赛,他们需要发挥自己的聪明才智,展现自己的实力。希望这次竞赛能够激发更多对信息学的热爱,培养更多的优秀人才。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值