今年的第几天?

题目描述
输入年、月、日,计算该天是本年的第几天。

输入描述:
包括三个整数年(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
#include
#include
#include
#include
#include
#include

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
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
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;
}
*/

你可能感兴趣的:(NKW,算法,数据结构,c++)