蓝桥杯 算法提高 日期计算(Java解题)
2018-03-16 13:04
387 查看
问题描述 已知2011年11月11日是星期五,问YYYY年MM月DD日是星期几?注意考虑闰年的情况。尤其是逢百年不闰,逢400年闰的情况。输入格式 输入只有一行
YYYY MM DD输出格式 输出只有一行
W数据规模和约定 1599 <= YYYY <= 2999
1 <= MM <= 12
1 <= DD <= 31,且确保测试样例中YYYY年MM月DD日是一个合理日期
1 <= W <= 7,分别代表周一到周日样例输入2011 11 11样例输出5
【解析】:先判断出某一年的1月1号为周几,如2018年的1月1日为周一,再判断输入的年份在2018之前还是之后,再根据输入的年份确定出离2018年1月1日有多少天,最后除以7取余得出结果。(注意闰年的判断)。【代码】:import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int y = sc.nextInt();
int m = sc.nextInt();
int d = sc.nextInt();
int mm[] = { 0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
int sum = 0;
/** 2018年1月1日为周1 */
if (y >= 2018) {
for (int i = 2018; i < y; i++) {
if (run(i))
sum += 366;
else
sum += 365;
}
for (int i = 0; i < m; i++) {
sum += mm[i];
}
sum += d;
if (m > 2 && run(y))
sum++;
if (sum % 7 == 0)
System.out.println(7);
else
System.out.println(sum % 7);
}
else {
for (int i = y + 1; i < 2018; i++) {
if (run(i))
sum += 366;
else
sum += 365;
}
for (int i = m + 1; i <= 12; i++) {
sum += mm[i];
}
sum += mm[m] - d;
if (m <= 2 && run(y))
sum++;
if (sum % 7 == 0)
System.out.println(7);
else
System.out.println(7 - sum % 7);
}
}
private static boolean run(int i) {
if ((i % 4 == 0
b344
&& i % 100 != 0) || (i % 400 == 0))
return true;
else
return false;
}
}
YYYY MM DD输出格式 输出只有一行
W数据规模和约定 1599 <= YYYY <= 2999
1 <= MM <= 12
1 <= DD <= 31,且确保测试样例中YYYY年MM月DD日是一个合理日期
1 <= W <= 7,分别代表周一到周日样例输入2011 11 11样例输出5
【解析】:先判断出某一年的1月1号为周几,如2018年的1月1日为周一,再判断输入的年份在2018之前还是之后,再根据输入的年份确定出离2018年1月1日有多少天,最后除以7取余得出结果。(注意闰年的判断)。【代码】:import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int y = sc.nextInt();
int m = sc.nextInt();
int d = sc.nextInt();
int mm[] = { 0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
int sum = 0;
/** 2018年1月1日为周1 */
if (y >= 2018) {
for (int i = 2018; i < y; i++) {
if (run(i))
sum += 366;
else
sum += 365;
}
for (int i = 0; i < m; i++) {
sum += mm[i];
}
sum += d;
if (m > 2 && run(y))
sum++;
if (sum % 7 == 0)
System.out.println(7);
else
System.out.println(sum % 7);
}
else {
for (int i = y + 1; i < 2018; i++) {
if (run(i))
sum += 366;
else
sum += 365;
}
for (int i = m + 1; i <= 12; i++) {
sum += mm[i];
}
sum += mm[m] - d;
if (m <= 2 && run(y))
sum++;
if (sum % 7 == 0)
System.out.println(7);
else
System.out.println(7 - sum % 7);
}
}
private static boolean run(int i) {
if ((i % 4 == 0
b344
&& i % 100 != 0) || (i % 400 == 0))
return true;
else
return false;
}
}
相关文章推荐
- 蓝桥杯 算法提高 日期计算(java)
- 蓝桥杯 ADV-127 算法提高 日期计算(java)
- 算法-蓝桥杯-算法提高 日期计算 (JAVA)
- 算法提高 日期计算 蓝桥杯java详解
- 蓝桥杯 算法提高VIP 陶陶摘苹果2(Java解题)
- 蓝桥杯 算法提高VIP Pascal三角(Java解题)
- 蓝桥杯 算法提高 队列操作(Java解题)
- 蓝桥杯-算法提高-日期计算
- 蓝桥杯 算法提高VIP 寻找三位数(Java解题)
- 蓝桥杯 算法提高VIP 最长单词(Java解题)
- 蓝桥杯 算法提高 9-1九宫格 (Java解题)
- 蓝桥杯 算法提高 12-1三角形 (Java解题)
- 蓝桥杯 算法提高VIP 素数求和(Java解题)
- 蓝桥杯 算法提高VIP 色盲的民主(Java解题)
- 蓝桥杯 算法提高 日期计算
- 算法提高 日期计算 蓝桥杯 详解
- 蓝桥杯 算法提高 最大乘积(Java解题)
- 蓝桥杯 算法提高VIP 数组输出(Java解题)
- 蓝桥杯 算法提高 三进制数位和(Java解题)
- 蓝桥杯——算法提高 日期计算