/* 程序问题注释开始
-
程序的版权和版本声明部分
-
Copyright © 2020,湖南工程职业技术学院信息工程学院学生
-
文件名称: 蓝桥杯赛题
-
作 者: 李 斌
-
完成日期: 2020 年 04 月 19日
-
对任务及求解方法的描述部分
-
问题描述
有些西方人比较迷信,如果某个月的13号正好是星期五,他们就会觉得不太吉利,用古人的说法,就是“诸事不宜”。请你编写一个程序,统计出在某个特定的年份中,出现了多少次既是13号又是星期五的情形,以帮助你的迷信朋友解决难题。
说明:
(1)一年有365天,闰年有366天,所谓闰年,即能被4整除且不能被100整除的年份,或是既能被100整除也能被400整除的年份;
(2)已知1998年1月1日是星期四,用户输入的年份肯定大于或等于1998年。 -
输入格式:输入只有一行,即某个特定的年份(大于或等于1998年)。
-
输出格式:输出只有一行,即在这一年中,出现了多少次既是13号又是星期五的情形。
-
样例输入
1998 -
样例输出
3 -
程序问题注释结束
*/
//2020.04.19 09.43
package 黑色星期五;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
// TODO 自动生成的方法存根
Scanner in=new Scanner(System.in);
//用户请输入年份
int year=in.nextInt();
//记录一年中天数
int day=0;
//记录当年前的年份天数星期的余数
int remainder=0;
//记录当年开始是星期几
int result=4;
//判断1998年后每一年是闰年还是平年
for(int i=1998;i<=year;i++)
{
//判断润年
if(i%4==0&&i%100!=0||i%400==0)
{
//闰年天数
day=366;
}
else
{
//平年天数
day=365;
}
//除当年的其它年的余数
if(i!=year)
{
//求余
remainder+=day%7;
}
}
//求当年开始是星期几
result=(remainder+result)%7;
//count计数,num取每月天数和
int count=0,num=0;
//循环每一个月
for(int i=0;i<12;i++)
{
//选择月份
switch(i)
{
//1,3,5,7,8,10月31天
case 1:case 3:case 5:case 7:case 8:case 10:
num+=31;
break;
//2月判断润平年
case 2:
if(day==365)
{
//平年28天
num+=28;
}
else
{
//闰年29天
num+=29;
}
break;
//4,6,9,11月30天
case 4:case 6:case 9:case 11:
num+=30;
break;
//0月不存在,所有不需要加前几月天数
default:
break;
}
//判断当月是否有13号为星期五
if((result+num+13-1)%7==5)
{
//计数
count++;
}
}
//输出当年有几个黑色星期五
System.out.println(count);
}
}
运行结果: