第十五届蓝桥杯省赛PythonB组D题【神奇闹钟】题解(AC)

在这里插入图片描述
请添加图片描述
请添加图片描述

题意分析

1970 − 01 − 01 1970-01-01 19700101 00 : 00 : 00 00:00:00 00:00:00 (下文称为 S S S)起,每 x x x 分钟会响一次闹钟,给定时间 T T T,请问上一次响闹钟的时间是何时?

具体思路

  1. 算出给定时间 T T T 距离 S S S 一共过多少分钟 p p p
  2. 通过当前分钟 p p p,算出上一次响闹钟距离 S S S 的分钟为 q = p − p % x q = p - p\%x q=pp%x
  3. 计算 T T T 之后 q q q 分钟的时间点应该是多少。
days = [0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]

def is_leap(y):
    return y % 400 == 0 or y % 4 == 0 and y % 100 != 0

def daysOfMonth(y, m):
    if m == 2:
        return 28 + is_leap(y)
    return days[m]

def betweenDays(y, m, d):
    yy, mm, dd = 1970, 1, 1
    res = 0
    while yy != y:
        res += 365 + is_leap(yy)
        yy += 1
    while mm != m:
        res += daysOfMonth(yy, mm)
        mm += 1
    res += d - 1
    return res

def get(y, m, d, h, mi):
    res = betweenDays(y, m, d) * 24 * 60
    res += h * 60
    res += mi
    return res

def nextDay(k):
    y, m, d, h, mi, s = 1970, 1, 1, 0, 0, 0
    while k >= (365 + is_leap(y)) * 24 * 60:
        k -= (365 + is_leap(y)) * 24 * 60
        y += 1
    while k >= daysOfMonth(y, m) * 24 * 60:
        k -= daysOfMonth(y, m) * 24 * 60
        m += 1
    while k >= 24 * 60:
        k -= 24 * 60
        d += 1
    h = k // 60
    k %= 60
    mi = k
    
    print("%d-%02d-%02d %02d:%02d:%02d" % (y, m, d, h, mi, s))

T = int(input())
for _ in range(T):
    s1, s2, s3 = input().split()
    y, m, d = map(int, s1.split('-'))
    h, mi, s = map(int, s2.split(':'))
    x = int(s3)
    
    k = get(y, m, d, h, mi)
    k -= k % x
    
    nextDay(k)

【在线测评】

在这里插入图片描述

  • 16
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值