跑步锻炼a

小蓝每天都锻炼身体。正常情况下,小蓝每天跑1 千米。如果某天是周一或者月初(1 日),为了激励自己,小蓝要跑2 千米。如果同时是周一或月初,小蓝也是跑2 千米。小蓝跑步已经坚持了很长时间,从2000 年1 月1 日周六(含)到2020 年10 月1 日周四(含)。请问这段时间小蓝总共跑步多少千米?
 

本题有三种解法:

法一:

借助datetime库直接获取日期,逐个遍历。

import datetime
start = datetime.date(2000, 1, 1)   #开始日期
end = datetime.date(2020, 10, 1)    #结束日期
days = datetime.timedelta(days=1)  #每次增加一天 
run = 0   #跑xx千米
 
while(start <= end):
    if(start.day == 1 or start.isoweekday()==1):     #一号或者周一
        run = run + 2
    else:
        run = run + 1
    start = start + days
print(run)

法二:

根据日期的规则,闰年二月29天,平年二月28天,起始的那天是周六,通过for循环遍历每一天,若为一号或者周一就跑2km,其他日期跑1km,知道2020年10月1日结束,并输出结果。

month1=[0,31,29,31,30,31,30,31,31,30,31,30,31]  #闰年各月天数
month2=[0,31,28,31,30,31,30,31,31,30,31,30,31]  #平年各月天数
run=0   #跑步数
mon=5   #周几
for year in range(2000,2021):
    #判断是闰年还是平年
    if ((year%4==0)and (year%100!=0))or(year%400==0):
        month=month1
    else:
        month=month2
    for m in range(1,13):   #1月到12月
        for d in range(1,month[m]+1):   #1号到month[m]号
            if (mon==0)or (d==1):       #月初或周一跑2km
                run=run+2
            else:
                run=run+1
            mon=(mon+1)%7    #取余使其不断循环
            if (year==2020)and(m==10)and(d==1):      #2020年10月1日结束
                print(run)
                break

法三:

运用excel,直接生成时间序列,统计总的天数,然后筛选出周一的天数,以及一号的天数和一号并且是周一的天数。

总的跑步数=总的天数+一号的天数+周一的天数-一号并且是周一的天数

运行结果

8879

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值