题目:给你一个日期,请你设计一个算法来判断它是对应一周中的哪一天。
输入为三个整数:day、month 和 year,分别表示日、月、年。
您返回的结果必须是这几个值中的一个 {"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"}。
解法:求天数与1971年1月1日的差值,因为已知1971年1月1日为星期五
代码:
class Solution(object):
def dayOfTheWeek(self, day, month, year):
"""
:type day: int
:type month: int
:type year: int
:rtype: str
"""
days=4+day
"""1971年1月1日是星期五"""
for i in range(1971,year):
if i % 400 == 0 or (i % 100 != 0 and i % 4 == 0):
days=days+366
else:
days=days+365
days = days % 7
d=["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"]
m1 = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
m2 = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
if year%400==0 or (year%100!=0 and year%4==0):
for i in range(month-1):
days=m2[i]+days
else:
for i in range(month-1):
days=m1[i]+days
print(d[days%7])
return d[days%7]



