点击前往试题目录: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;
}