Sofdar Ali's Next Day
Sofdor Ali goes to Karwan Bazar every Thursday to eat Jilapi! But he often forgets what day is Thursday! In fact, he struggles to figure out the exact date for any day. He has an alarm clock in his pocket and it only rings at a specific time of the day. But this old clock does not give him information about the date. Sofdor has come up with a solution to this problem. Whenever he needs to know what day it is, he buys a newspaper. Newspapers always have dates written in it, and that solves Sofdor’s problem. Well, at least for a day.
But buying newspapers is costly for Sofdor Ali, as he has to spend most of his money for buying important equipment for his experiment. So Sofdor is wondering, how he could reduce the cost of buying newspapers. Then he decided, he would buy a newspaper for one day and then calculate the next date from the newspaper’s date. That will reduce the cost of buying newspapers to half, as Sofdor only has to buy one newspaper in two days.
Now you have to write a program that will help Sofdor Ali to calculate the date of the next day, once the current date is given.
Input
The first line of the input is an integer () denoting the number of test cases. Each of the next lines describe 3 integers (), () and () which denotes day, month and year.
You can safely assume that every date that is given as an input is a valid date.
Output
For each date, print the next date in the following format:
Day Month, Year
Day must be formatted with a leading zero if it is less than 10. Month must be one of the following: Jan, Feb, Mar, Apr, May, Jun, Jul, Aug, Sep, Oct, Nov, Dec.
Sample
Input | Output |
---|---|
4 1 1 1993 20 10 1999 15 5 2009 11 11 1993 | 02 Jan, 1993 21 Oct, 1999 16 May, 2009 12 Nov, 1993 |
According to Wikipedia, a leap year can be identified in the following way:
If a year is not exactly divisible by 4 then it is a common year. Otherwise, if a year is not exactly divisible by 100 then it is a leap year. Otherwise, if a year is not exactly divisible by 400 then it is a common year. Else it is a leap year.
Solutions:
#include <bits/stdc++.h>
int main()
{
long long T, D, M, Y, leapYear = 0;
long long days[12] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
char months[12][5] = {"Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"};
scanf("%lld", &T);
while (T--) {
leapYear = 0;
scanf(" %lld %lld %lld", &D, &M, &Y);
if ((Y % 4) != 0) leapYear = 0;
else if ((Y % 100) != 0) leapYear = 1;
else if ((Y % 400) != 0) leapYear = 0;
else leapYear = 1;
//if (((Y % 400) == 0) || ((Y % 4 == 0) && (Y % 100 != 0))) leapYear = 1;
D++;
if (leapYear == 1) {
if ((D > 29) && (M == 2)) {
D = 1;
M++;
} else if ((D <= 29) && (M == 2)) {
// Do nothing
} else if (D > days[M - 1]) {
D = 1;
M++;
}
if (M > 12) {
M = 1;
Y++;
}
} else if (leapYear == 0) {
if (D > days[M - 1]) {
D = 1;
M++;
}
if (M > 12) {
M = 1;
Y++;
}
}
if (D < 10) {
printf("0%lld %s, %lld\n", D, months[M - 1], Y);
} else {
printf("%lld %s, %lld\n", D, months[M - 1], Y);
}
}
return 0;
}
0 Comments