计算天数[2]

2023-12-17 05:39:17

本题要求实现一个简单函数,计算年year、月month和日day对应的是该年的第几天。其中1、3、5、7、8、10、12月有31天,4、6、9、11月有30天,2月平年有28天,闰年有29天。判断闰年的条件是:能被 4 整除但不能被 100 整除,或者能被 400 整除。

函数接口定义:

在这里描述函数接口。例如:
int day_of_year(int year, int month);

其中yearmonthday是用户传入的参数。函数返回年year、月month和日day对应的是该年的第几天。

裁判测试程序样例:

# include <stdio.h>
int day_of_year(int year, int month, int day);
 
int main(void) 
{
    int day, month, year;
    
    scanf("%d%d%d", &year, &month, &day);
    printf("%d\n", day_of_year(year, month, day));
    
    return 0;
}

/* 请在这里填写答案 */

输入样例1:

2000 3 1

输出样例1:

61

输入样例2:

1981 3 1

输出样例2:

60
#include <stdio.h>

int day_of_year(int year, int month, int day);

int main(void)
{
    int day, month, year;

    scanf("%d%d%d", &year, &month, &day);
    printf("%d\n", day_of_year(year, month, day));

    return 0;
}

int day_of_year(int year, int month, int day)
{
    int a[13][1] = { {0},{31},{28},{31},{30},{31},{30},{31},{31},{30},{31},{30},{31} };
    int sum = day;
    if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0)
        a[2][0] = 29;//只用改变一个数组元素即可
    for (int i = 0; i < month; i++)
    {
        sum += a[i][0];
    }
    return sum;
}

?不能这样定义:
?

int a[13][1];
    if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0)
        a[13][1] = { {0},{31},{29},{31},{30},{31},{30},{31},{31},{30},{31},{30},{31} };
    else
        a[13][1] = { {0},{31},{28},{31},{30},{31},{30},{31},{31},{30},{31},{30},{31} };

因为a[13][1] 是一个数组元素

?

?

?

文章来源:https://blog.csdn.net/Y2663438690/article/details/135039651
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。