【蓝桥杯】黑色星期五1(Java实现)


/* 程序问题注释开始

  • 程序的版权和版本声明部分

  • 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);
	}

}

运行结果:
运行结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值