题目
这次的题目也不是很难。测试程序将随机给你一个空格分隔了年、月、日的日期(其中的数字都是没有前导零的,也就是说7不会被写成07)。你将需要判断这个日期在我们的公历体系内是否真实存在。如果存在则输出YES,否则输出NO(注意输出的字母都一定是大写字母)。
测试程序给出的测试输入数据中,年、月、日都是正整数(也就是大于零的整数),均不大于3000
已知,一年有 1 月到 12 月,共12个不同的月份;其中 1 月、3 月、5 月、7 月、8 月、10 月、12 月有31个合法的日,分别为 1 日到 31 日;4 月、6 月、9 月、11 月有30个合法的日,分别为 1 日到 30 日。对于闰年,2 月有29个合法的日,分别为 1 日到 29 日;对于平年(不是闰年的年称为平年),2 月有 28个合法的日,分别为 1 日到 28日。
对于不大于 3000 年的年份,闰年遵循如下规律:
· 非整百年,能被4整除的为闰年。
· 整百年,能被400整除的是闰年。
样例
样例一
样例输入
2016 2 29
样例输出
YES
样例二
样例输入
1900 2 29
样例输出
NO
样例三
样例输入
2016 13 32
样例输出
NO
程序
#include<bits/stdc++.h>
using namespace std;
int main(){
int y, m, d;
bool yflag = false;
cin >> y >> m >> d;
if(y % 400 == 0 || (y % 100 != 0 && y % 4 == 0)){
yflag = true;
}if(m > 12){
cout << "NO";
}else{
if((m == 2 && yflag && d <= 29) || (m == 2 && not yflag && d < 29)){
cout << "YES";
}else if((m == 1 || m == 3 || m == 5 || m == 7 || m == 8 || m == 10 || m == 12) && d <= 31){
cout << "YES";
}else if((m == 4 || m == 6 || m == 9 || m == 11) && d <= 30){
cout << "YES";
}else{
cout << "NO";
}
}
return 0;
}