-
Notifications
You must be signed in to change notification settings - Fork 26
/
1507.ReformatDate(List).py
41 lines (36 loc) · 1.46 KB
/
1507.ReformatDate(List).py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
"""
Given a date string in the form Day Month Year, where:
- Day is in the set {"1st", "2nd", "3rd", "4th", ..., "30th", "31st"}.
- Month is in the set {"Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul",
"Aug", "Sep", "Oct", "Nov", "Dec"}.
- Year is in the range [1900, 2100].
Convert the date string to the format YYYY-MM-DD, where:
- YYYY denotes the 4 digit year.
- MM denotes the 2 digit month.
- DD denotes the 2 digit day.
Example:
Input: date = "20th Oct 2052"
Output: "2052-10-20"
Constraints:
- The given dates are guaranteed to be valid, so no error handling is n
ecessary.
"""
#Difficulty: Easy
#110 / 110 test cases passed.
#Runtime: 48 ms
#Memory Usage: 13.7 MB
#Runtime: 48 ms, faster than 100.00% of Python3 online submissions for Reformat Date.
#Memory Usage: 13.7 MB, less than 100.00% of Python3 online submissions for Reformat Date.
#Sorry. We do not have enough accepted submissions to show distribution chart.
class Solution:
def reformatDate(self, date: str) -> str:
months = {"Jan":"01", "Feb":"02", "Mar":"03", "Apr":"04", "May":"05",
"Jun":"06", "Jul":"07", "Aug":"08", "Sep":"09", "Oct":"10",
"Nov":"11", "Dec":"12"}
d = date.split()
d.reverse()
d[2] = d[2][:-2]
if len(d[2]) < 2:
d[2] = "0" + d[2]
d[1] = months[d[1]]
return "-".join(d)