解题思路:先判断是否是闰年,再判断月份数n,最后将前n-1 个月有多少天相加,再加上第n个月的天数
一种方法是判断闰年,再判断是那个月,直接计算,这种方法就会有12次判断
第二种方法是将每年12个月的天数放到一个数组里,在将数组的前n-1 个数字相加,加上第n个月的天数即可;闰年和非闰年的每个月的天数是不同的两个数组
//1, 输入一个日期,判断是这一年的第几天
#include "stdafx.h"
int FindDate(int year, int month, int day)
{
bool IsGapYear = false;
int days = day;
int DayOfYear[12] = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 }; //非闰年12个月每个月的天数
int DayOfGapYear[12] = { 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 }; //闰年12个月每个月的天数
if (year <= 0 || month <= 0 || month > 12 || day <= 0 || day > 31) //判断非法输入
return 0;
//判断是否为闰年
if (year % 400 == 0 || (year % 4 == 0 && year % 100 != 0))
IsGapYear = true;
for (int i = 0; i < month - 1; i++)
{
if (IsGapYear)
{
days += DayOfYear[i];
}
else
days += DayOfGapYear[i];
}
return days;
}
int _tmain(int argc, _TCHAR* argv[])
{
//测试2016年11月10日
int day = FindDate(2016, 11, 10);
printf("%d\n", day);
return 0;
}
结果: