????????泽勒一致性是由克里斯汀 · 泽勒开发的用于计算某天是星期几的算法。
这个公式是:
h = (q + (26(m + 1) / 10) + k + k/4 + j/4 + 5j) % 7
其中:
- h是一个星期中的某一天(0 为星期六;1 为星期天;2 为星期一; 3 为星期二;4 为星期三;5 为星期四;6 为星期五)。
- ? q 是某月的第几天。
- m 是月份(3 为三月,4 为四月,...,12 为十二月)。一月和二月分别记为上一年的13 和 14 月。
- j 是世纪数(即|year / 100|)。
- k 是该世纪的第几年(即year % 100)。注意,公式中的除法执行一个整数相除。?
- 一月和二月在公式中使用 13 和 14 表示的。所以需要将用户输入的月份 1 转换为 13,将月份 2 转换为 14,同时将年份改为前一年。
编写程序,提示用户输入年、月和该月的哪一天,然后显示它是一周中的星期几。
package pack2;
import java.util.Scanner;
public class DayIs {
public static void main(String[] args) {
try(Scanner input = new Scanner(System.in);) {
System.out.print("Enter year: (e.g., 2012): ");
int year = input.nextInt();
System.out.print("Enter month: 1-12: ");
int month = input.nextInt();
System.out.print("Enter the day of the month: 1-31: ");
int day = input.nextInt();
System.out.println(day(year, month, day));
}
}
//某天是星期几
public static String day(int year, int month, int day) {
String[] days = {"Saturday", "Sunday", "Monday", "Tuesday", "Wednesday",
"Thursday", "Friday"};
int m = month,k, j;
if(month < 1 || month > 12) //如果月份不合法,抛出异常
throw new IllegalArgumentException("Error Month: "+month);
if(day < 1 || day > 31) //如果天数不合法,抛出异常
throw new IllegalArgumentException("Error Day: "+day);
if(month == 1 || month == 2) { //处理月份为1或2的情况
m = (month == 1) ? 13 : 14; //如果月份为1,m = 13;否则,m = 14
year--; //年份减一
}
k = year % 100; //世纪的第几年
j = Math.abs(year / 100); //世纪数
int h = (day + (26 * (m + 1)) / 10 + k + (k / 4) + (j / 4) + 5 * j) % 7;
return "Day of the week is "+days[h];
}
}
?
?
|