602 - What Day Is It?
Posted: Tue May 21, 2002 11:09 am
Although my program did all the test inputs correctly, I got a WA. Could someone please print test inputs and their corresponding outputs or check my algorithm and tell me what's wrong with it ?
Thanks in advance
[c]
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
int valid(int d, int m, int y);
char *mname(int month);
char *wday (int d, int m, int y);
int DaysInYear(int year);
int DaysInMonthInYear(int month, int year);
long DaysSinceZ(int day, int month, int year);
int main(void)
{
int day = 1, month = 1, year = 1;
while(1) {
scanf("%d %d %d", &month, &day, &year);
if (!(day && month && year)) break;
if(valid(day, month, year))
printf("%s %i, %i is a %s\n", mname(month), day, year, wday(day, month, year));
else
printf("%i/%i/%i is an invalid date.\n", month, day, year);
}
return 0;
}
int valid(int d, int m, int y)
{
if (m>12) return 0;
if (d>DaysInMonthInYear(m, y)) return 0;
return 1;
}
char *mname(int month)
{
char *c = malloc(10);
switch (month) {
case 1:
strcpy(c, "January");
break;
case 2:
strcpy(c, "February");
break;
case 3:
strcpy(c, "March");
break;
case 4:
strcpy(c, "April");
break;
case 5:
strcpy(c, "May");
break;
case 6:
strcpy(c, "June");
break;
case 7:
strcpy(c, "July");
break;
case 8:
strcpy(c, "August");
break;
case 9:
strcpy(c, "September");
break;
case 10:
strcpy(c, "October");
break;
case 11:
strcpy(c, "November");
break;
case 12:
strcpy(c, "December");
break;
}
return c;
}
char *wday (int d, int m, int y)
{
char *c = malloc(10);
int dd;
dd = ((DaysSinceZ(d, m, y)+1)%7) + 1;
switch (dd) {
case 1:
strcpy(c, "Monday");
break;
case 2:
strcpy(c, "Tuesday");
break;
case 3:
strcpy(c, "Wednesday");
break;
case 4:
strcpy(c, "Thursday");
break;
case 5:
strcpy(c, "Friday");
break;
case 6:
strcpy(c, "Saturday");
break;
case 7:
strcpy(c, "Sunday");
break;
}
return c;
}
int DaysInYear(int year)
{
if ((!(year % 4) && (year % 100)) || !(year % 400))
return 366;
else
return 365;
}
int DaysInMonthInYear(int month, int year)
{
switch(month)
{
case 2:
if ((!(year % 4) && (year % 100)) || !(year % 400))
return 29;
else
return 28;
case 4:
case 6:
case 9:
case 11:
return 30;
case 1:
case 3:
case 5:
case 7:
case 8:
case 10:
case 12:
return 31;
default:
return 0;
}
}
long DaysSinceZ(int day, int month, int year)
{
int n;
long c = 0;
for (n = 0; n < year; n += 1)
c += DaysInYear(n);
for (n = 1; n < month; n += 1)
c += DaysInMonthInYear(n, year);
c += day;
if (year > 1752) c-=11;
if ((year == 1752) && (month > 9)) c-=11;
if ((year == 1752) && (month == 9) && (day > 2)) c-= 11;
return c;
}
[/c][/c]
Thanks in advance
[c]
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
int valid(int d, int m, int y);
char *mname(int month);
char *wday (int d, int m, int y);
int DaysInYear(int year);
int DaysInMonthInYear(int month, int year);
long DaysSinceZ(int day, int month, int year);
int main(void)
{
int day = 1, month = 1, year = 1;
while(1) {
scanf("%d %d %d", &month, &day, &year);
if (!(day && month && year)) break;
if(valid(day, month, year))
printf("%s %i, %i is a %s\n", mname(month), day, year, wday(day, month, year));
else
printf("%i/%i/%i is an invalid date.\n", month, day, year);
}
return 0;
}
int valid(int d, int m, int y)
{
if (m>12) return 0;
if (d>DaysInMonthInYear(m, y)) return 0;
return 1;
}
char *mname(int month)
{
char *c = malloc(10);
switch (month) {
case 1:
strcpy(c, "January");
break;
case 2:
strcpy(c, "February");
break;
case 3:
strcpy(c, "March");
break;
case 4:
strcpy(c, "April");
break;
case 5:
strcpy(c, "May");
break;
case 6:
strcpy(c, "June");
break;
case 7:
strcpy(c, "July");
break;
case 8:
strcpy(c, "August");
break;
case 9:
strcpy(c, "September");
break;
case 10:
strcpy(c, "October");
break;
case 11:
strcpy(c, "November");
break;
case 12:
strcpy(c, "December");
break;
}
return c;
}
char *wday (int d, int m, int y)
{
char *c = malloc(10);
int dd;
dd = ((DaysSinceZ(d, m, y)+1)%7) + 1;
switch (dd) {
case 1:
strcpy(c, "Monday");
break;
case 2:
strcpy(c, "Tuesday");
break;
case 3:
strcpy(c, "Wednesday");
break;
case 4:
strcpy(c, "Thursday");
break;
case 5:
strcpy(c, "Friday");
break;
case 6:
strcpy(c, "Saturday");
break;
case 7:
strcpy(c, "Sunday");
break;
}
return c;
}
int DaysInYear(int year)
{
if ((!(year % 4) && (year % 100)) || !(year % 400))
return 366;
else
return 365;
}
int DaysInMonthInYear(int month, int year)
{
switch(month)
{
case 2:
if ((!(year % 4) && (year % 100)) || !(year % 400))
return 29;
else
return 28;
case 4:
case 6:
case 9:
case 11:
return 30;
case 1:
case 3:
case 5:
case 7:
case 8:
case 10:
case 12:
return 31;
default:
return 0;
}
}
long DaysSinceZ(int day, int month, int year)
{
int n;
long c = 0;
for (n = 0; n < year; n += 1)
c += DaysInYear(n);
for (n = 1; n < month; n += 1)
c += DaysInMonthInYear(n, year);
c += day;
if (year > 1752) c-=11;
if ((year == 1752) && (month > 9)) c-=11;
if ((year == 1752) && (month == 9) && (day > 2)) c-= 11;
return c;
}
[/c][/c]