【Python】2020年蓝桥杯省赛真题——跑步锻炼

问题描述

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

问题解答(三种方法)
1、Excel表格求解

(1)填入初始日期后更改日期类型,并根据结束日期填充2000-01-01至2020-10-01间的日期。


(2)为了方便随后筛选统计,另起两列,分别以星期x和天数的形式表示日期。通过公式和填充可以填充B列为星期x的形式,借助Excel中DAY函数和填充则可以将日期显示为序列数表示的天数。
     
     
(3)另起一列,初始化步数为1并添加首行标签,进行筛选,将周一和月初的步数均设置为2。

(4)对步数栏进行求和统计得出结果。

2、调用datetime模块
import datetime

rolling_date = datetime.date(2000, 1, 1)
end_date = datetime.date(2020, 10, 1)
days = datetime.timedelta(days=1)
count = 0

while(rolling_date <= end_date):
    if(rolling_date.day == 1 or rolling_date.isoweekday()==1):
        count += 2
    else:
        count += 1
    rolling_date += days

print(count)
-----------------------------------------------------------------------
Output: 8879
3、自己乖乖写循环 + 选择结构
year = 2000
month = 1
data_index = 1
week_index = 6
flags = []  # 用于存放每天跑步的公里数

while (year != 2020) or (month != 10) or (data_index != 2):
    if week_index == 1 or data_index == 1:
        flags.append(2)
    else:
        flags.append(1)
     
    if month == 4 or month == 6 or month == 9 or month == 11:
        if not (data_index % 30):
            month += 1
        data_index = data_index % 30 + 1
    elif month == 2:
        # 判断是否为闰年
        if (not (year % 4) and (year % 100)) or not (year % 400):
            if not (data_index % 29):
                month += 1
            data_index = data_index % 29 + 1
        else:
            if not (data_index % 28):
                month += 1
            data_index = data_index % 28 + 1
    else:
        if month == 12:
            if not (data_index % 31):
                month = month % 12 + 1
                year += 1    # 新的一年
        else:
            if not (data_index % 31):
                month += 1
        data_index = data_index % 31 + 1
        
    week_index = week_index % 7 + 1
    
print(sum(flags))
-----------------------------------------------------------------------
Output: 8879
  • 9
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值