Hackerrank - Time Delta Solution
When users post an update on social media,such as a URL, image, status update etc., other users in their network are able to view this new post on their news feed. Users can also see exactly when the post was published, i.e, how many hours, minutes or seconds ago.
When users post an update on social media,such as a URL, image, status update etc., other users in their network are able to view this new post on their news feed. Users can also see exactly when the post was published, i.e, how many hours, minutes or seconds ago.
Since sometimes posts are published and viewed in different time zones, this can be confusing. You are given two timestamps of one such post that a user can see on his newsfeed in the following format:
Day dd Mon yyyy hh:mm:ss +xxxx
Here +xxxx represents the time zone. Your task is to print the absolute difference (in seconds) between them.
Input Format
The first line contains , the number of testcases.
Each testcase contains lines, representing time and time .
Constraints
- Input contains only valid timestamps
- .
Output Format
Print the absolute difference in seconds.
Sample Input 0
2
Sun 10 May 2015 13:54:36 -0700
Sun 10 May 2015 13:54:36 -0000
Sat 02 May 2015 19:54:36 +0530
Fri 01 May 2015 13:54:36 -0000
Sample Output 0
25200
88200
Explanation 0
In the first query, when we compare the time in UTC for both the time stamps, we see a difference of 7 hours. which is 7x3600 seconds or 25200 seconds.
Similarly, in the second query, time difference is 5 hours and 30 minutes for time zone adjusting for that we have a difference of 1 day and 30 minutes. Or 24x3600+30x60=>88200
Solution in Python
from datetime import datetime
def delta(d1,d2):
f= '%a %d %b %Y %H:%M:%S %z'
d1 = datetime.strptime(d1, f)
d2 = datetime.strptime(d2, f)
diff = (d2-d1).total_seconds()
return abs(int(diff))
for _ in range(int(input())):
print(delta(input(), input()))
For all kind of date formating
Directive |
Meaning |
Example |
Notes |
---|---|---|---|
|
Weekday as locale’s abbreviated name. |
Sun, Mon, …, Sat
(en_US);
So, Mo, …, Sa
(de_DE)
|
(1) |
|
Weekday as locale’s full name. |
Sunday, Monday, …,
Saturday (en_US);
Sonntag, Montag, …,
Samstag (de_DE)
|
(1) |
|
Weekday as a decimal number, where 0 is Sunday and 6 is Saturday. |
0, 1, …, 6 |
|
|
Day of the month as a zero-padded decimal number. |
01, 02, …, 31 |
|
|
Month as locale’s abbreviated name. |
Jan, Feb, …, Dec
(en_US);
Jan, Feb, …, Dez
(de_DE)
|
(1) |
|
Month as locale’s full name. |
January, February,
…, December (en_US);
Januar, Februar, …,
Dezember (de_DE)
|
(1) |
|
Month as a zero-padded decimal number. |
01, 02, …, 12 |
|
|
Year without century as a zero-padded decimal number. |
00, 01, …, 99 |
|
|
Year with century as a decimal number. |
1970, 1988, 2001, 2013 |
|
|
Hour (24-hour clock) as a zero-padded decimal number. |
00, 01, …, 23 |
|
|
Hour (12-hour clock) as a zero-padded decimal number. |
01, 02, …, 12 |
|
|
Locale’s equivalent of either AM or PM. |
AM, PM (en_US);
am, pm (de_DE)
|
(1), (2) |
|
Minute as a zero-padded decimal number. |
00, 01, …, 59 |
|
|
Second as a zero-padded decimal number. |
00, 01, …, 59 |
(3) |
|
Microsecond as a decimal number, zero-padded on the left. |
000000, 000001, …, 999999 |
(4) |
|
UTC offset in the form +HHMM or -HHMM (empty string if the the object is naive). |
(empty), +0000, -0400, +1030 |
(5) |
|
Time zone name (empty string if the object is naive). |
(empty), UTC, EST, CST |
|
|
Day of the year as a zero-padded decimal number. |
001, 002, …, 366 |
|
|
Week number of the year (Sunday as the first day of the week) as a zero padded decimal number. All days in a new year preceding the first Sunday are considered to be in week 0. |
00, 01, …, 53 |
(6) |
|
Week number of the year (Monday as the first day of the week) as a decimal number. All days in a new year preceding the first Monday are considered to be in week 0. |
00, 01, …, 53 |
(6) |
|
Locale’s appropriate date and time representation. |
Tue Aug 16 21:30:00
1988 (en_US);
Di 16 Aug 21:30:00
1988 (de_DE)
|
(1) |
|
Locale’s appropriate date representation. |
08/16/88 (None);
08/16/1988 (en_US);
16.08.1988 (de_DE)
|
(1) |
|
Locale’s appropriate time representation. |
21:30:00 (en_US);
21:30:00 (de_DE)
|
(1) |
|
A literal |
% |