问题描述;
分别输出1900年1月1日到给定日期。每月13号星期6-5的总个数
#include <iostream>
#include<iomanip>
#include <cmath>
#include<bits/stdc++.h>
#include <stack>
#include<string>
using namespace std;
int main()
{
int m;
cin>>m;
int days[7]={0};
//记住前一个月份的当天的星期
int flag;
//控制年
for(int i=1900;i<1900+m;i++ )
{
//控制月
for(int j=1;j<=12;j++)
{
//设置初始值
if(j==1&&i==1900)
{
days[5]++;
flag=5;
}
else if(j==2||j==4||j==6||j==8||j==9||j==11||j==1)
{
//所有的结果加之后都需要取余
days[(flag+31%7)%7]++;
flag=(flag+31%7)%7;
}
else if(j==3)
{
if(i% 4 == 0 && i% 100 != 0 || i% 400 == 0)
{
days[(flag+29%7)%7]++;
flag=(flag+29%7)%7;
}
else
{
days[(flag+28%7)%7]++;
flag=(flag+28%7)%7;
}
}
else
{
days[(flag+30%7)%7]++;
flag=(flag+30%7)%7;
}
}
}
cout<<days[5]<<" "<<days[6]<<" "<<days[0]<<" "<<days[1]<<" "<<days[2]<<" "<<days[3]<<" "<<days[4]<<endl;
return 0;
}