洛谷P1202题解
题目描述
13 号又是一个星期五,那么 13号在星期五比在其他日子少吗?
为了回答这个问题,写一个程序,要求计算每个月的十三号落在周一到周日的次数。给出 nn 年的一个周期,要求计算 1900 年 11 月 11 日至 1900+n-1900+n−1 年 12 月 31 日中十三号落在周一到周日的次数。
这里有一些你要知道的:
1、1900 年 1 月 1 日是星期一。
2、4,6,11 和 9 月有 30 天,其他月份除了 2 月都有 31 天,闰年 2 月有 29 天,平年 2 月有 28 天。
3、年份可以被 4 整除的为闰年 ( 1992=4*498 所以 1992 年是闰年,但是 1990 年不是闰年 )。
4、以上规则不适合于世纪年。可以被 400 整除的世纪年为闰年,否则为平年。所以,1700,1800,1900,2100年是平年,而 2000 年是闰年。
输入格式
一个正整数 n。
输出格式
依次输出周六、日、一、二、三、四、五在 13 日出现的次数。
题解
这很明显是一个大模拟
用两层for可以搞定(一个年份,一个月份)
我们用一个变量a模拟13日出现在的星期数 每过一个月就加一个数:
1,3,5,7,8,10,12 a+=3(31%7==3)
4,6,9,11 a+=2(30%7==2)
2月特判闰年(如果是整百数,必须是400的倍数;其余必须是4的倍数)。
上代码:
最后,看我这么努力,给个赞,投个币换一道黄题,不过分吧

