题目描述
输入年、月、日,计算该天是本年的第几天。
输入描述:
包括三个整数年(1<=Y<=3000)、月(1<=M<=12)、日(1<=D<=31)。
输出描述:
输入可能有多组测试数据,对于每一组测试数据,
输出一个整数,代表Input中的年、月、日对应本年的第几天。
示例1
输入
1990 9 20
2000 5 1
输出
263
122
题目解析:主要就是2月份的天数,需要判断闰年,year % 4 == 0 && year % 100 != 0 或者 year % 400 == 0,就是闰年。
代码:
#include<iostream>
#include<stdio.h>
#include<string.h>
#include<math.h>
#include<algorithm>
#include<vector>
#include<map>
using namespace std;
int main(){
map<int,int> mp;
int year,month,day;
while(cin >> year >> month >>day){
//闰年
int sum = 0;
if((year % 4 == 0 && year % 100 != 0) || year % 400 == 0){
for(int i = 1 ;i <= (month-1) ; i++){
if(i == 1 || i == 3 || i == 5 || i == 7 || i == 8 || i == 10 || i == 12){
sum += 31;
}else if(i == 2){
sum += 29;
}else{
sum += 30;
}
}
sum = sum + day;
cout << sum << endl;
}else{
for(int i = 1 ;i <= (month-1) ; i++){
if(i == 1 || i == 3 || i == 5 || i == 7 || i == 8 || i == 10 || i == 12){
sum += 31;
}else if(i == 2){
sum += 28;
}else{
sum += 30;
}
}
sum = sum + day;
cout << sum << endl;
}
}
return 0;
}
/*
#include<stdio.h>
#include<math.h>
#include<algorithm>
#include<string.h>
#include<fstream>
#include<iostream>
#include<iomanip>
#include<vector>
#include<map>
#include<set>
#include<stack>
#include<queue>
using namespace std;
int months[12] = {31,28,31,30,31,30,31,31,30,31,30,31};
void judice(int year){
if((year % 4== 0 && year % 100 != 0) || year % 400 == 0){
months[1] = 29;
}else{
months[1] = 28;
}
}
int main(){
int year , month , day;
while(cin >> year >> month >> day){
judice(year);
int rst = 0;
for(int i = 0 ; i < month -1; i++){
rst += months[i];
}
rst += day;
cout << rst << endl;
}
return 0;
}
*/