201812-2 CCF认证考试 小明放学 Python版

本文深入探讨了交通信号灯状态变化的模拟算法,通过分析红、黄、绿三种灯的状态转换逻辑,结合输入参数,设计了一套高效的计算流程。算法考虑了不同灯的初始状态和转换时间,实现了信号灯在特定条件下的精确模拟。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这道题首先要解决轮数问题用取余来做,然后在每种情况下判断灯的变化,情况为未转灯,转红灯,转绿灯,转黄灯

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)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值