星期几——蓝桥杯(Python解法)

已知2011年11月11日是星期五,问YYYY年MM月DD日是星期几?
    注意考虑闰年的情况。尤其是逢百年不闰,逢400年闰的情况。
输入格式
  输入只有一行
  YYYY MM DD
输出格式
  输出只有一行
  W
数据规模和约定
  1599 <= YYYY <= 2999
  1 <= MM <= 12
  1 <= DD <= 31,且确保测试样例中YYYY年MM月DD日是一个合理日期
  1 <= W <= 7,分别代表周一到周日
样例输入
2011 11 11
样例输出
5

Python示例(输入必须为真实存在且和为题目要求相一致的输入,例如1111年11月11日和2011年2月30日就不能作为输入,类似边界条件待补充)

a = &amp;quot;2011 11 11&amp;quot;

def ifRunNian(y1):
    y = int(y1)
    if y >= 1599 and y <= 2999:
        if y%4==0 :
            if y%100==0:
                if y%400==0:
                    return 366
                else:
                    return 365
            else:
                return 366
        else:
            return 365
    else:
        return -1

def month2day(y1, m1):
    m = int(m1)
    yb = ifRunNian(y1)
    if m <= 12 and m >= 1:
        if m == 1 or m == 3 or m == 5 or m == 7 or m == 8 or m == 10 or m == 12:
            return 31
        elif m == 4 or m == 6 or m == 9 or m == 11:
            return 30
        elif m == 2:
            if yb == 366:
                return 29
            elif yb == 365:
                return 28
        print(m)

def getDeltaYear(y1):
    y = int(y1)
    deltaYList = []
    if y < 2011 and y <= 2999:
        for i in range(2011-y):
            deltaYList.append(y+i)
    elif y>=2011 and y <= 2999:
        for i in range(y-2011):
            deltaYList.append(2011+i)
    return tuple(deltaYList)

def getDeltaDay(y1, m1, d1):
    deltaAllDay = 0
    y = int(y1)
    m = int(m1)
    d = int(d1)
    deltaMList = []
    dy = getDeltaYear(y1)
    if y < 2011 or (y == 2011 and m < 11) or (y == 2011 and m == 11 and d < 11):
        if dy != ():
            for i in dy:
                if i == dy[0]:
                    for j in range(m, 13):
                        # print(int(j))
                        md =  month2day(i, j)
                        deltaAllDay += md
                    deltaAllDay -= d
                else:
                    deltaAllDay += ifRunNian(i)
            for j in range(1, 11):
                deltaAllDay += month2day(int(i)+1, j)
            deltaAllDay += 11
        else:
            i = 2011
            for j in range(m, 11):
                md = month2day(i, j)
                deltaAllDay += md
            deltaAllDay -= d
            deltaAllDay += 11
        deltaAllDay = -deltaAllDay
    # elif y < 2011 or (y == 2011 and m < 11) or (y == 2011 and m == 11 and d < 11):
    elif y > 2011 or (y == 2011 and m > 11) or (y == 2011 and m == 11 and d > 11):
        if dy != ():
            print(dy)
            for i in dy:
                if i == dy[0]:
                    for j in range(11, 13):
                        deltaAllDay += month2day(i, j)
                    deltaAllDay -= 11
                else:
                    deltaAllDay += ifRunNian(i)
            for j in range(1, m):
                deltaAllDay += month2day(int(i)+1, j)
            deltaAllDay += d
        else:
            i = 2011
            for j in range(11, m):
                md = month2day(i, j)
                deltaAllDay += md
            deltaAllDay -= 11
            deltaAllDay += d

    return deltaAllDay

def day2week(deltaAllDay):
    if deltaAllDay < 0:
        deltaAllDay = - deltaAllDay
        e = 5- deltaAllDay % 7
        print(e)
        while e <= 0:
            e += 7
        while e > 7:
            e -= 7
        print(f'星期{e}')
    else:
        e = 5 + deltaAllDay % 7
        while e <= 0:
            e += 7
        while e > 7:
            e -= 7
        print(f'星期{e}')

print(a)
ymd = a.split(&amp;quot; &amp;quot;)
y, m, d = (ymd[0], ymd[1], ymd[2])
print(f'{y}, {m}, {d}')
# day2week(y, m, d)

k = getDeltaDay(1949, 10, 1)
print(k)
day2week(k)
print(month2day(2012, 2))
全部评论

相关推荐

行云流水1971:这份实习简历的优化建议: 结构清晰化:拆分 “校园经历”“实习经历” 板块(当前内容混杂),按 “实习→校园→技能” 逻辑排版,求职意向明确为具体岗位(如 “市场 / 运营实习生”)。 经历具象化:现有描述偏流程,需补充 “动作 + 数据”,比如校园活动 “负责宣传” 可加 “运营公众号发布 5 篇推文,阅读量超 2000+,带动 300 + 人参与”;实习内容补充 “协助完成 XX 任务,效率提升 X%”。 岗位匹配度:锚定目标岗位能力,比如申请运营岗,突出 “内容编辑、活动执行” 相关动作;申请市场岗,强化 “资源对接、数据统计” 细节。 信息精简:删减冗余表述(如重复的 “负责”),用短句分点,比如 “策划校园招聘会:联系 10 + 企业,组织 200 + 学生参与,到场率达 85%”。 技能落地:将 “Office、PS” 绑定经历,比如 “用 Excel 整理活动数据,输出 3 份分析表;用 PS 设计 2 张活动海报”,避免技能单独罗列。 优化后需强化 “经历 - 能力 - 岗位需求” 的关联,让实习 / 校园经历的价值更直观。 若需要进一步优化服务,私信
实习,投递多份简历没人回...
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务