日历问题C++


题目描述
在我们现在使用的日历中, 闰年被定义为能被4整除的年份,但是能被100整除而不能被400整除的年是例外,它们不是闰年。例如:1700, 1800, 1900 和 2100 不是闰年,而 1600, 2000 和 2400是闰年。

给定从公元2000年1月1日开始逝去的天数,你的任务是给出这一天是哪年哪月哪日星期几。
输入
输入包含若干行,每行包含一个正整数,表示从2000年1月1日开始逝去的天数。输入最后一行是?1,
不必处理。可以假设结果的年份不会超过9999。
输出
对每个测试样例,输出一行,该行包含对应的日期和星期几。格式为“YYYY-MM-DD DayOfWeek”, 
其中 “DayOfWeek” 必须是下面中的一个:
 "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday" and "Saturday“。
样例输入
1730
1740
1750
1751
-1
样例输出
2004-09-26 Sunday
2004-10-06 Wednesday
2004-10-16 Saturday
2004-10-17 Sunday

#include<iostream>
#include<iomanip>
using namespace std;

int isleapyear(int year){
	if((year%4==0)||(year%100!=0&&year%400==0))
	    return 0;
    else 
        return 1;
}
int  main(){
	int a;
	string weekday[7]={"Saturday","Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday" };
	int n;
    while(cin>>n&&n!=-1){
	      int year=2000,month=1,day=1;
			a=n%7;
			while(n>=366){
				if(isleapyear(year)==0)
				{n=n-366;
		         year++;
				 }
				 else if(isleapyear(year)==1)
				 {n=n-365;
		         year++;
				 }
			}
				if(isleapyear(year)==0){				
				int a[13]={0,31,29,31,30,31,30,31,31,30,31,30,31};
				while(n>a[month]){
					n=n-a[month];
					month++;
				}}
				else if(isleapyear(year)==1){				
				int a[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
				while(n>a[month]){
					n=n-a[month];
					month++;
				}}	
			    cout<<setfill('0');
		        cout<<year<<"-"<<setw(2)<<month<<"-"<<setw(2)<<n+1<<" "<<weekday[a]<<endl;
    }
	return 0;
}
  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值