计算年月日

给出年、月、日,计算该日是该年的第几天。

要求:判断瑞年和计算顺序天的需要使用两个函数实现,函数声明如下:

// 判断是否为闰年

int LeapYear(int year);

// 计算当年的顺序天

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

答案

#include <iostream>

using namespace std;

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

int LeapYear(int year);

int main()

{

	int year, month, day; // 年月日

	int orderDay = 0; // 一年第几天

	printf("Please input date (for example: 2018-11-29):\n ");

	scanf_s("%d-%d-%d", &year, &month, &day);

	orderDay = GetOrderDay(year, month, day);

	printf("%d-%d-%d is the %dth day in this year.\n",

		year, month, day, orderDay);

	return 0;

}

// 计算当年的顺序天

int GetOrderDay(int year, int month, int day)

{

	int i; // 循环变量

	int orderDay = 0; // 顺序天

	int monthList[12] = { 31,28,31,30,31,30,31,31,30,31,30,31 };
	// 如果为瑞年,二月份为29天

	if (LeapYear(year))

	{

		monthList[1] = 29;

	}

	for (i = 0; i < month - 1; i++) // 累加所在月之前天数

	{

		orderDay += monthList[i];

	}

	orderDay += day; // 累加本月天数

	return orderDay;

}

// 判断是否为闰年

int LeapYear(int year)

{

	int leap = 0;

	if ((year % 4 == 0 && year % 100 != 0) || (year % 400 == 0))
	{

		leap = 1;

	}

	return leap;

}

  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值