csp試題2:日期計算
-
- 題目
- 分析
- 代碼
- 總結
題目
問題描述
給定一個年份y和一個整數d,問這一年的第d天是幾月幾日?
注意閏年的2月有29天。滿足下面條件之一的是閏年:
1) 年份是4的整數倍,而且不是100的整數倍;
2) 年份是400的整數倍。
輸入格式
輸入的第一行包含一個整數y,表示年份,年份在1900到2015之間(包含1900和2015)。
輸入的第二行包含一個整數d,d在1至365之間。
輸出格式
輸出兩行,每行一個整數,分别表示答案的月份和日期。
樣例1
輸入:
2015
80
輸出:
3
21
樣例2
輸入:
2000
40
輸出:
2
9
分析
想要知道第d天是幾月幾日,首先要知道的是這一年中12個月份各自的天數,12個月中隻有2月的天數是會變化的,我們需要根據不同年份來設定2月的天數。
知道了12個月的天數後,用d依次去減每個月份的天數,當所得結果小于等于0時,該月份就是對應的月份數,進行這次減法前的d就是該月的日數。
代碼
/*
20190910
ccf試題2:日期計算
*/
#include <iostream>
using namespace std;
int main(){
//接受資料
int year;
int days;
cin >>year >>days;
//計算日期
//初始化月份資料
int month_days[12] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
if((year%4 == 0 && year%100 != 0) || (year%400 == 0)){
month_days[1] = 29;
}
//計算
int month = 0;
int day;
while(days > 0){
day = days;
days = days - month_days[month];
month++;
}
cout <<month<<endl;
cout <<day<<endl;
return 0;
}
總結
迄今為止見過的最簡單的ccf試題2。