题目描述
2014年6月2日是端午节,也是小粽子同学的18岁生日。可以推算出小粽子同学出生于星期日,经历了6575天(出生当天也算1天)。
输入
输入一个日期,格式是YYYY-MM-DD。比如输入小粽子的生日:1996-06-02。
输出
输出2个数。第1个数表示此人从出生到2014年6月2日所经过的天数,第2个数表示这个人的出生日期是星期几。
重要提示(!!!!!):
题目中的六月二日是周日是指1996年的,并非是指2014年6月2日是周日(勿踩坑)
代码思路:
分情况1.同年同月,只用天数相减就好了
2.同年不同月,用当前月份到月末的天数+整月份天数(用循环)+2;
3.不同年.用当前年份到年底天数+整年份天数.注意闰平年+所求年月日天数
#include <iostream>
using namespace std;
int main()
{
int y,m,d;
int sum=1;
int month[12]={31,28,31,30,31,30,31,31,30,31,30,31};//定义好闰年与平年的每月天数
int month1[12]={31,29,31,30,31,30,31,31,30,31,30,31};
scanf("%04d-%02d-%02d",&y,&m,&d);
int y1=2014,m1=6,d1=2;
int last=2;
for(int i=0;i<5;i++) //2014年刚开始到所求日期中间的天数
{
last=last+month[i];
}
if(y==2014&&m==6) //同年同月不同日
{
sum=sum+d1-d;
}
else if(y==2014&&m!=6) //同年不同月(注意此处只能用else if而不能用if)
{
sum=month[m-1]-d+2;
for(int i=m+1;i<5;i++)
{
sum=sum+month[i];
}
}
else //不同年
{
if(y%4==0&&y%100!=0)
{
sum=sum+month1[m-1]-d+last;
for(int i=m;i<12;i++)
{
sum+=month1[i];
}
}
else
{
sum=sum+month[m-1]-d+last;
for(int i=m;i<12;i++)
{
sum+=month[i];
}
}
for(int i=y+1;i<2014;i++)
{
if(i%4==0&&i%100!=0)
sum+=366;
else if(i%100==0&&i%400==0)
sum+=366;
else
sum+=365;
}
}
cout<<sum<<endl;
sum=sum-2;
int w=sum%7;
w=7-w;
cout<<w<<endl;
return 0;
}