这道题首先要解决轮数问题用取余来做,然后在每种情况下判断灯的变化,情况为未转灯,转红灯,转绿灯,转黄灯
ps:这一道题要用到第一题小明上学的条件:灯的变化红->绿->黄
满分答案:
r,y,g = input().split()
r,y,g = int(r),int(y),int(g)
n = int(input())
light_begin = [[0 for i in range(2)] for j in range(n)]
time = 0
for i in range(n):
light_begin[i] = input().split()
a = time % (r+y+g)
b = int(light_begin[i][1])
c = int(light_begin[i][0])
if c == 0:
time = time + b
elif c == 1:
if a<=b:
time = time + b - a
else:
if a<b+g:
pass
elif a>=b+g and a<b+g+y:
time = time + (b+g+y)-a+r
elif a>=b+g+y:
time = time + b+g+y+r - a
elif c == 2:
if a<=b:
time = time + b +r -a
else:
if a<b+r:
time = time+(b+r-a)
elif a>=b+r and a<b+r+g:
pass
elif a >= b+r+g:
time = time + b+g+r+y-a + r
elif c == 3:
if a<=b:
pass
else:
if a<b+y:
time = time + (b+y)-a +r
elif a>=b+y and a<b+y+r:
time = time + (b+y+r)-a
elif a>=b+y+r:
pass
print(time)