我们经常要计算,从今天往后N天之后是哪一天(哪年哪月哪日)。现在我们就可以编写一个程序,推算指定日期之后的第N天是什么日期。
年 月 日
(年月日+N天后的)年.月.日
序号 | 测试输入 | 期待的输出 | 额外进程 |
---|---|---|---|
1 | 2012 4 9↵ 91↵ |
2012.7.9↵ |
0 |
2 | 2013 1 1↵ 364↵ |
2013.12.31↵ |
0 |
我们第一个肯定想到的是能不能利用【日期】根据日期求星期
事实上是可以的,我们可以先算出日期X的天数(距离元年1月1日)A,然后加上N,再逆推A+N对应日期X’
int day(int y, int m, int d) {
int a[15] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
if (y % 4 == 0 && y % 100 != 0 || y % 400 == 0)a[2] = 29;
int i, s;
for (i = 1; i <= m - 1; i++) { d += a[i]; }
s = 365 * (y - 1) + (y - 1) / 4 - (y - 1) / 100 + (y - 1) / 400 + d;
return s;
}
int main()
{
int y, m, d, add;
scanf("%d %d %d\n%d", &y, &m, &d, &add);
int d1 = day(y, m, d), d2 = d1 + add;
for (; d2 > (365 * (y - 1) + (y - 1) / 4 - (y - 1) / 100 + (y - 1) / 400); y++)
{
if (d2 <= (365 * (y)+(y) / 4 - (y) / 100 + (y) / 400))printf("%d.", y);
}
d2 -= (365 * (y - 2) + (y - 2) / 4 - (y - 2) / 100 + (y - 2) / 400);
int mm[15] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
if ((y - 1) % 4 == 0 && (y - 1) % 100 != 0 || (y - 1) % 400 == 0)mm[2] = 29;
int i = 1;
for (; mm[i] < d2; i++, d2 -= mm[i])
{
if (mm[i + 1] >= d2);
}
if (i == 13)i = 12;
printf("%d.%d\n", i, d2);
}
(这段代码还有很大的优化空间)
还有没有别的方式呢?
这样写代码实在是太丑了
要不试试模拟日历翻页?
#include
int md[13] = { 0,31,0,31,30,31,30,31,31,30,31,30,31 };
int main()
{
int year, month, day, m;
scanf("%d%d%d%d", &year, &month, &day, &m);
for (int i = 0; i < m; i++)
{
if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0) md[2] = 29;
else md[2] = 28;
if (day == md[month])
{
month++, day = 1;
if (month == 13)
year++, month = 1;
}
else day++;
}
printf("%d.%d.%d\n", year, month, day);
return 0;
}