53 求n天后的日期

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;
}
发布了142 篇原创文章 · 获赞 5 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/weixin_39910081/article/details/104798518
53
今日推荐