第几天--acm.njupt

来源:互联网 发布:安卓游戏数据备份 编辑:程序博客网 时间:2024/06/09 17:24
/*在我们现在使用的日历中, 闰年被定义为能被4整除的年份,但是能被100整除而不能被400整除的年是例外,它们不是闰年。例如:1700, 1800, 1900 和 2100 不是闰年,而 1600, 2000 和 2400是闰年。

给定公元2000年1月1日后的某年某月某日(包括2000年1月1日),你的任务:(1)给出这一天从公元2000年1月1日开始逝去的天数,(2)判断这一天是当年的第几天。


输入

输入包含若干行,每行包含三个空格间隔的正整数,它们分别表示年、月、日。输入最后一行是−1, 不必处理。可以假设结果的年份不会超过9999。

输出

多组,每组两行,分别为每行输入所代表的一天从公元2000年1月1日开始逝去的天数、在当年的第几天。

样例输入

2000 1 1
2009 3 14
-1

样例输出

0
1
3360
73*/

#include<stdio.h>

int M[12] = {31,28,31,30,31,30,31,31,30,31,30,31};

int isRuinian(int year)
{
    if (year % 100 == 0)
    {
        if (year % 400 == 0)
            return 1;
        else
            return 0;
    }
    else
    {
        if (year % 4 == 0)
            return 1;
        else
            return 0;
    }
}

int countdate(int y,int m,int d)
{
    int dates = 0;
    int i;
    for (i = 2000;i < y;i++)
    {
        if (isRuinian(i))
            dates += 366;
        else
            dates += 365;
    }

    for (i = 0;i < m-1;i++)
        dates += M[i];
    dates += d-1;

    if (isRuinian(y) && m>=2)
        dates++;

    return dates;
}

int thisyeardate(int y,int m,int d)
{
    int i,dates=0;
    for (i = 0;i < m-1;i++)
        dates += M[i];
    dates += d;

    if (isRuinian(y) && m>=2)
        dates++;

    return dates;
}

int main()
{
    int year,month,date;

    while (scanf ("%d",&year)!=EOF && year != -1 )
    {
        scanf ("%d%d",&month,&date);
        printf ("%d\n",countdate(year,month,date));
        printf ("%d\n",thisyeardate(year,month,date));
    }

    return 0;

}


来源:http://acm.njupt.edu.cn/acmhome/problemdetail.do?&method=showdetail&id=1008

0 0