注意数据类型的选取,考虑到t的最大值106, 路口处等2x106时间
n的最大值105, 总时间的临接最大值是2x1011, 约为238 ,32位的int或者long型显然是不够用的。
关于整形数据类型
在64位机器上
short in 和 unsigned short int是16位
int 和unsigned int 和 long int 和 unsigned long int 是 32位
long long int 和 unsigned long long int 是 64位
C++
#include<iostream>
using namespace std;
int main(){
int r,y,g,T,n,k,t;
long long int all_time = 0;
cin>>r>>y>>g;
T = r+y+g; //T是一个红绿灯周期的时间
cin>>n;
while(n--){
cin>>k>>t;
if(k==0) all_time+=t;
else if(k==1)
if(all_time%T<t) all_time=all_time + t - all_time%T;
else if(all_time%T<t+g) ;
else all_time = all_time+t+g+y+r-all_time%T;
else if(k==2){
if(all_time%T<t+r) all_time = all_time + t + r - all_time%T;
else if(all_time%T<t+r+g);
else all_time = all_time + T -all_time%T + t + r;
}
else if(k==3)
if(all_time%T<t) ;
else if(all_time%T<t+y+r) all_time = all_time+t+y+r - all_time%T;
}
cout<<all_time;
}
C
#include<stdio.h>
int main()
{
int r,y,g,n,k,t,tt;
long long sum_t=0;
scanf("%d%d%d",&r,&y,&g);
scanf("%d",&n);
tt=r+y+g;
while(n--)
{
scanf("%d%d",&k,&t);
if(k==0) sum_t=sum_t+t;
else if(k==1){
if((sum_t%tt)<t) sum_t=sum_t-(sum_t%tt)+t;
else if((sum_t%tt)<t+g);
else sum_t=sum_t-(sum_t%tt)+t+g+y+r;
}
else if(k==2){
if((sum_t%tt)<t+r) sum_t=sum_t-(sum_t%tt)+t+r;
else if((sum_t%tt)<t+r+g) ;
else sum_t=sum_t-(sum_t%tt)+t+g+r+r+y;
}
else if(k==3){
if((sum_t%tt)<t);
else if((sum_t%tt)<t+r+y) sum_t=sum_t-(sum_t%tt)+t+r+y;
}
}
printf("%lld",sum_t);
return 0;
}