当前位置: 代码迷 >> 综合 >> 试题 算法训练 黑色星期五(Java)
  详细解决方案

试题 算法训练 黑色星期五(Java)

热度:1   发布时间:2023-12-03 06:31:15.0

试题 算法训练 黑色星期五(Java)

资源限制

时间限制:1.0s 内存限制:512.0MB

问题描述
  有些西方人比较迷信,如果某个月的13号正好是星期五,他们就会觉得不太吉利,用古人的说法,就是“诸事不宜”。请你编写一个程序,统计出在某个特定的年份中,出现了多少次既是13号又是星期五的情形,以帮助你的迷信朋友解决难题。
  说明:(1)一年有365天,闰年有366天,所谓闰年,即能被4整除且不能被100整除的年份,或是既能被100整除也能被400整除的年份;(2)已知1998年1月1日是星期四,用户输入的年份肯定大于或等于1998年。
  输入格式:输入只有一行,即某个特定的年份(大于或等于1998年)。
  输出格式:输出只有一行,即在这一年中,出现了多少次既是13号又是星期五的情形。
输入输出样例

样例输入

1998

样例输出

3

import java.util.Scanner;
import java.util.Calendar;public class Main {public static void main(String[] args){Scanner sc = new Scanner(System.in);int iyear = sc.nextInt();int count = 0;Calendar cl = Calendar.getInstance();for(int i = 0; i <= 11; i++){        //Calendar类中规定一月到十二月分别是0到11cl.set(iyear, i , 13);  //确定年份和日子,再遍历12个月份if(cl.get(Calendar.DAY_OF_WEEK) == 6){    //Calendar类中规定周日为1,周一到周日分别是:2 3 4 5 6 7 1count++;}}System.out.println(count);}
}

需要特别强调的是,本方法完全是取巧的解法,完全依赖于强大的Calendar类库没有用到出题人的思路(毕竟还告诉我们闰年的规则) 思路不唯一,仅供参考!

顺便简单提供一些Calendar类中的常用输出参考

        // 获得年份System.out.println("现在是:" + c.get(Calendar.YEAR) + "年");// 获得月份System.out.println("现在是:" + (c.get(Calendar.MONTH)+1) + "月");//获得日期System.out.println("现在是:" + c.get(Calendar.DATE) + "号");System.out.println("现在是:" + c.get(Calendar.DAY_OF_MONTH) + "号");// 获得这是今年的第几天System.out.println("现在是今年第" + c.get(Calendar.DAY_OF_YEAR) + "天");// 获得今天周几System.out.println("现在是星期:" + (c.get(Calendar.DAY_OF_WEEK)-1) );// 获得今天是这个月的第几周System.out.println("现在是第:" + c.get(Calendar.DAY_OF_WEEK_IN_MONTH) + "周" );// 12小时制的时间System.out.println("现在是:" + c.get(Calendar.HOUR) + "点");// 24小时制的时间System.out.println("现在是:" + c.get(Calendar.HOUR_OF_DAY) + "点");// 分钟数System.out.println("现在是:" + c.get(Calendar.MINUTE) + "分");// 秒数System.out.println("现在是:" + c.get(Calendar.SECOND) + "秒");// 毫秒System.out.println("现在是:" + c.get(Calendar.MILLISECOND) + "毫秒");

  相关解决方案