【日期】计算后续日期

【日期】计算后续日期

我们经常要计算,从今天往后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;
}

你可能感兴趣的:(学习笔记-乐学,c++,算法,c语言)