53 求n天后的日期
作者: Turbo时间限制: 2S章节: 函数
问题描述 :
写一个函数,传入年月日,计算它的第二天,并返回该日期。由用户输入年月日和一个n值,使用前述函数,计算该日期加n天的日期为多少。
输入说明 :
输入year,month,day和n共4个正整数,以空格分隔。n的值不超过2000。
输出说明 :
输出计算得到的结果年月日共3个正整数,整数之间以一个空格分隔,行首与行尾无多余空格。
输入范例 :
2000 1 1 366
输出范例 :
2001 1 1
#include<stdio.h>
int month[13]={29,31,28,31,30,31,30,31,31,30,31,30,31};
int isLeapYear(int n);
int main(){
int i,y,m,d,offset,sum,temp;
while(~scanf("%d %d %d %d",&y,&m,&d,&offset)){
sum=0;
for(i=1;i<m;i++){
sum+=month[i];
}
sum+=d;
if(isLeapYear(y)&&m>2){
//如果是闰年2月为29天多一天
sum++;
}
temp=(offset+sum);
if(isLeapYear(y)){
//当前日期是闰年
if(temp>366){
//闰年366天
while(1){
if(isLeapYear(y)){
temp-=366;
}else{
temp-=365;
}
y++;
if(temp<365){
break;
}
}
if(isLeapYear(y)){
month[2]=29;
}
for(i=1;i<=12;i++){
if(temp<=month[i]){
break;
}
temp-=month[i];
}
month[2]=28;
printf("%d %d %d\n",y,i,temp);
}else{
month[2]=29;
for(i=1;i<=12;i++){
if(temp<=month[i]){
break;
}
temp-=month[i];
}
printf("%d %d %d\n",y,i,temp);
month[2]=28;
}
}else{
//当前日期不是闰年
if(temp>365){
while(1){
if(isLeapYear(y)){
temp-=366;
}else{
temp-=365;
}
y++;
if(temp<365){
break;
}
}
if(isLeapYear(y)){
month[2]=29;
}
for(i=1;i<=12;i++){
if(temp<=month[i]){
break;
}
temp-=month[i];
}
month[2]=28;
printf("%d %d %d\n",y,i,temp);
}else{
temp=offset+d;
for(i=1;i<=12;i++){
if(temp<=month[i]){
break;
}
temp-=month[i];
}
printf("%d %d %d\n",y,i,temp);
}
}
}
return 0;
}
int isLeapYear(int n){
if((n%4==0&&n%100!=0)||n%400==0){
return 1;
}
return 0;
}