CCF CSP 編程題目和解答-----試題名稱:日期計算-------201509-2

問題描述
試題編號: 201509-2
試題名稱: 日期計算
時間限制: 1.0s
內存限制: 256.0MB
問題描述:
問題描述
  給定一個年份y和一個整數d,問這一年的第d天是幾月幾日?
  注意閏年的2月有29天。滿足下麪條件之一的是閏年:
  1) 年份是4的整數倍,而且不是100的整數倍;
  2) 年份是400的整數倍。
輸入格式
  輸入的第一行包含一個整數y,表示年份,年份在1900到2015之間(包含1900和2015)。
  輸入的第二行包含一個整數d,d在1至365之間。
輸出格式
  輸出兩行,每行一個整數,分別表示答案的月份和日期。
樣例輸入
2015
80
樣例輸出
3
21
樣例輸入
2000
40
樣例輸出
2   
9
 

#include<iostream>
#include<algorithm>
#include<vector>

using namespace std;

bool bigmonth(int i,int& d)
{
	bool end=false;
	if(d>31)
				{
					d-=31;
				}
				else
				{
					end=true;
					cout<<i<<endl<<d<<endl;					
				}
				
				
	return end;
}
int smallmonth(int i,int& d)
{
	bool end=false;
	if(d>30)
				{
					d-=30;
				}
				else
				{
					end=true;
					cout<<i<<endl<<d<<endl;					
				}
				
				
	return end;
}

int main()
{
	int y,d;
	cin>>y>>d;
	
	bool flag=false;
	if((y%4==0&&y%100!=0)||(y%400==0))
		flag=true;
	
	
	bool end=false;
	for(int i=1;i<=12;i++)
	{
		switch(i)
		{
			case 1:
			case 3:
			case 5:
			case 7:
			case 8:
			case 10:
			case 12:
			{
				end=bigmonth(i,d);
				break;
			}
			case 2:
			{
				if(flag)
				{
					if(d>29)
					  d-=29;
				  else{
					  end=true;
					cout<<i<<endl<<d<<endl;	
				  }
				}
				else
				{
					if(d>28)
					  d-=28;
				  else{
					  end=true;
					cout<<i<<endl<<d<<endl;	
				  }
				}
				break;
			}
			case 4:
			case 6:
			case 9:
			case 11:
			{
				end=smallmonth(i,d);
				break;
			}
		}
		if(end)
			break;
	}
	
	//system("pause");
}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章