一,题目描述
根据输入的日期,计算是这一年的第几天。。
详细描述:
输入某年某月某日,判断这一天是这一年的第几天?。
接口设计及说明:
/*****************************************************************************
Description : 数据转换
Input Param : year 输入年份
Month 输入月份
Day 输入天
Output Param :
Return Value : 成功返回0,失败返回-1(如:数据错误)
*****************************************************************************/
public static int iConverDateToDay(int year, int month, int day)
{
/* 在这里实现功能,将结果填入输入数组中*/
return 0;
}
/*****************************************************************************
Description :
Input Param :
Output Param :
Return Value : 成功:返回outDay输出计算后的第几天;
失败:返回-1
*****************************************************************************/
public static int getOutDay()
{
return 0;
}
输入描述:
输入三行,分别是年,月,日
输出描述:
成功:返回outDay输出计算后的第几天;
失败:返回-1
示例1
输入
2012
12
31
输出
366
二,程序分析
- 这题比较简单,操作也比较简单。
- 用一个数组存放每月的累积天数 输入的日期天数= 当月的天数 + 当月之前的累积天数 如果包含二月,再去判断是否为 闰年,如果是闰年,再加1天即可
- 分析过程加代码分析,我相信就容易写出来了
三,程序代码
#include<iostream>
using namespace std;
int main()
{
//首先可以写出不是闰年的日期的总数
int array[13] = {0,31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334, 365 };
int year,month,day;
int sum = 0;
while (cin >> year >> month >> day)
{
sum = 0;
sum += array[month -1];
sum += day;
//这里判断是否位闰年,如果是,那么在总数上加1,反之不加
if ((year % 4 == 0 && year % 100 == 0 ) || (year % 400 == 0))
{
sum += 1;
}
cout << sum << endl;
}
return 0;
}
四,运行结果
感觉不错的话,记得关注一个再走啊!!!