Java、某天是星期几

        泽勒一致性是由克里斯汀 · 泽勒开发的用于计算某天是星期几的算法。

这个公式是:

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];
	}
}

 

 

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值