Fork me on GitHub

CSP201509-2:日期计算

引言:CSP(http://www.cspro.org/lead/application/ccf/login.jsp)是由中国计算机学会(CCF)发起的"计算机职业资格认证"考试,针对计算机软件开发、软件测试、信息管理等领域的专业人士进行能力认证。认证对象是从事或将要从事IT领域专业技术与技术管理人员,以及高校招考研究生的复试对象。

 

  • 问题描述

  给定一个年份y和一个整数d,问这一年的第d天是几月几日?

  注意闰年的2月有29天。满足下面条件之一的是闰年:

  1) 年份是4的整数倍,而且不是100的整数倍;

  2) 年份是400的整数倍。

  • 输入格式

  输入的第一行包含一个整数y,表示年份,年份在1900到2015之间(包含1900和2015)。

  输入的第二行包含一个整数d,d在1至365之间。

  • 输出格式

  输出两行,每行一个整数,分别表示答案的月份和日期。

  • 样例输入

    2015

    80

  • 样例输出

    3

    21

  • 样例输入

    2000

    40

  • 样例输出

    2

    9

     

  • 源代码

# include <stdio.h>

 

int main(void)

{

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

    int y; //年份

    int d; //整数

    scanf("%d", &y);

    scanf("%d", &d);

    

    if ((y%4 == 0 && y%100 != 0) || y%400 == 0) //是闰年

    {

        days[1] = 29;

    }

    

    for (int i = 0; i < 12; i++)

    {

        if (d <= days[i])

        {

            int month = i + 1;

            int day = d;

            printf("%d\n", month);

            printf("%d\n", day);

            break;

        }

        else

        {

            d -= days[i];

        }

    }

    

    return 0;

}

posted @ 2018-02-22 16:24  husterzxh  阅读(538)  评论(0编辑  收藏  举报