201812-2 小明放学 100分 140ms

点击前往试题目录:https://blog.csdn.net/best335/article/details/99550556
在这里插入图片描述
注意这次是出发时刻,所以要推算出到达该信号灯时的灯状态。

#include<iostream>
using namespace std;
long long r,y,g,n,ans,k,t,mod,tmp;
long long get(const long long &t){
	if(t<r)
		return r-t;
	if(t<r+g)
		return 0L;
	return mod-t+r;
}
int main(){
	cin>>r>>y>>g>>n,mod=r+y+g,ans=0L;
	for(int i=0;i<n;++i){
		cin>>k>>t,tmp=ans;
		switch(k){
			case 0L:
				ans+=t;
				break;
			case 1L://r
				ans+=get((r-t+ans)%mod);
				break;
			case 2L://y
				ans+=get((mod-t+ans)%mod);
				break;
			case 3L://g
				ans+=get((g-t+r+ans)%mod);
				break;
		}
	}
	cout<<ans<<endl;
	return 0;
}
发布了107 篇原创文章 · 获赞 21 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/best335/article/details/100061419