SK


私信TA

用户名:1973231998

访问量:18482

签 名:

成功只是一时的,失败才是主旋律,笑着面对失败是主要的。

等  级
排  名 261
经  验 5682
参赛次数 0
文章发表 59
年  龄 0
在职情况 学生
学  校 *
专  业

  自我简介:

解题思路:

个人方法:site标记每月初位置,公式就是(site+当月天数)%7,(从0开始的位置);然后就是输出,用格式化输出printf()是真的舒服。

参考代码:

#include<bits/stdc++.h>
using namespace std;
int m[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
#define pd_y(x) ((x%4==0&&x%100!=0)||x%400==0)?true:false       //判断闰年
int main()
{
	int year, month,site=1,t=0;
	cin >> year >> month;
	if (year < 2007) return 0;
	for (int i = 2007; i <year; i++)
	{
		if (!pd_y(i))
		{
			m[2] = 28;
			for (int j = 1; j <= 12; j++)
			{
				site = (site + m[j]) % 7;
			}
		}
		else
		{
			m[2] = 29;
			for (int j = 1; j <= 12; j++)
			{
				site = (site + m[j]) % 7;
			}
		}
	}
	if (pd_y(year)) m[2] = 29;
	else m[2] = 28;
	for (int j = 1; j <month; j++)
	{
		site = (site + m[j]) % 7;
	}
	cout << "---------------------" << endl;
	cout << " Su Mo Tu We Th Fr Sa" << endl;
	cout << "---------------------" << endl;
	t = site;
	for (int j = site; j > 0; j--)
	{
		cout << "   ";           //三个空格
	}
	for (int i = 1; i <=m[month];i++)
	{
		printf(" %2d", i);
		t++;
		if (t == 7)
		{
			cout << endl;
			t = 0;
		}
		if (i == m[month]&&t!=0) cout << endl; //免得两次回车
	}
	cout << "---------------------" << endl;
}


 

0.0分

4 人评分

  评论区