居左


私信TA

用户名:JZ50

访问量:70430

签 名:

楼下你的分数已经再次被超越!!快刷!!

等  级
排  名 32
经  验 13566
参赛次数 2
文章发表 109
年  龄 0
在职情况 学生
学  校 99
专  业

  自我简介:

TA的其他文章

解题思路:
    先得出第y年1月1日为星期几, 然后逐月循环查找13号是否为星期五





注意事项:





参考代码:

import java.util.Scanner;

public class C1609 {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		while (sc.hasNext()) {
			F(sc.nextInt());
		}
		sc.close();
	}
	
	private static void F(int y){
		int d = 4; //1998年1月1日为星期四
		for(int i = 1998; i <= y-1; i++){
			if((i % 400 == 0) || (i%4 == 0 && i%100 != 0))
				d += 366;
			else
				d += 365;
		}
		d %= 7; //得到第y年1月1日为星期d
		int sum = 0, count = 0;
		for(int m = 0; m < 12; m++){
			if(m > 0){
				switch(m){
					case 2:
						if((y%400 == 0) || (y%4 == 0 && y%100 != 0))
							sum += 29;
						else
							sum += 28;
						break;
					case 4:
					case 6:
					case 9:
					case 11:
						sum += 30;
						break;
					default:
						sum += 31;
				}
			}
			
			if((d+sum+12) % 7 == 5)
				count++;
		}
		
		System.out.println(count);
	}
}


 

0.0分

1 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区