2020年2月9日 星期日

判断是平年,还是润年

#include<iostream>
#include<iomanip>
using namespace std;
//1900年1月1号是星期一

int nyear(int year)//判断是平年,还是润年
{
if(year%400==0||(year%4==0&&year%100!=0))
   return 366;
   else
   return 365;
}

int nmonth(int m,int y)  //根据年份和月份,判断是那一个月的天数
{
   if(m==1||m==3||m==5||m==7||m==8||m==10||m==12)
   return 31;
   else if(nyear(y)==366&&m==2)
   return 29;
   else if(nyear(y)==365&&m==2)
   return 28;
   else
   return 30;
}

int getDays(int year, int month)//输入年份和月份确定到1900年1月1日总共多少天
{
   int i;
   int sum=0;
   if(year>1900)
      for(i=1900;i<year;i++)
      sum+=nyear(i);
   if(month>1)
      for(i=1;i<month;i++)
      sum+=nmonth(i,year);

   return sum;     //返回总共多少天;
}

int main()
{
   int i,j,year,month,day,sum,daycount,cases=1;

   while(cin>>year>>month)
   {
      sum=getDays(year,month);
      day=sum%7;  //这里算出来这个月的一号前面需要几个空格;等于0的话,前面就不需要空格
      daycount=nmonth(month,year);//算出这个月的天数
      cout<<"Case "<<cases++<<": "<<year<<"年"<<month<<"月"<<endl;
      cout<<"Mon Tue Wed Thu Fri Sat Sun"<<endl;
      for(i=0;i<day%7;i++)
         cout<<"    ";//
      for(i=1,j=day+1;i<=daycount;i++,j++)
      {
         cout<<setw(4)<<setiosflags(ios::left)<<i;
         if(j%7==0) cout<<endl;
      }
      cout<<endl;
   }

   return 0;
}
//原出處https://blog.csdn.net/rain_qingtian/article/details/16845111

沒有留言:

張貼留言

algorithm

 #include <iostream> #include <string.h> using namespace std; int main(int argc, char** argv)  { for(int j=2;j<=100;j++)//j...