日期A + 天数 = 日期B
一般给出三个变量中的两个,让你求剩下的一个,下面看一道清华大学上机复试题
可以将输入的日期看做是日期B,而日期A为隐藏的,可以看做是上一年的最后一天,或者是今年的第一天,所以我们需要求中间经过的天数
1.先写一个二维数组表示中间经过的天数,0月有0天,1月有31天,而二月需要分个类,一个是29,一个是28
2.写一个函数判断某年是否为闰年,能否整除4,但是不能整除100,或者该年可以整除400
3.把当年的天数开始累加
#include<iostream>
#include<cstdio>
using namespace std;
int dayTable[2][13]{
{0,31,28,31,30,31,30,31,31,30,31,30,31},
{0,31,29,31,30,31,30,31,31,30,31,30,31}
};//这种语法要会写
bool isLeapYear(int year){//判断是否为闰年
if ((year%4==0&&year%100!=0)||(year%400==0)){
return true;
}else{
return false;
}
}
int main(){
int year,month,day;
while(scanf("%d%d%d",&year,&month,&day)!=EOF){
int number = 0;
int row = isLeapYear(year);
for(int j = 0;j < month; ++j){
number += dayTable[row][j];// bool true 对应 int 1
}
number += day;
printf("%d\n",number);
}
return 0;
}