LeetCode-1185. 一周中的第几天

给你一个日期,请你设计一个算法来判断它是对应一周中的哪一天。

输入为三个整数:day、month 和 year,分别表示日、月、年。

您返回的结果必须是这几个值中的一个 {"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"}。


 

示例 1:

输入:day = 31, month = 8, year = 2019
输出:"Saturday"
示例 2:

输入:day = 18, month = 7, year = 1999
输出:"Sunday"
示例 3:

输入:day = 15, month = 8, year = 1993
输出:"Sunday"
 

提示:

给出的日期一定是在 1971 到 2100 年之间的有效日期。


 

本来以为这道题非常简单,查一查相关的API就可以了,没想到小丑竟又是我自己,这道题官解和三叶都用的是模拟法,而不是去找规律啥的,因为这种题目根本没法造轮子,上几个造出这种轮子的人,管这个轮子叫xxx公式……于是就有其中一个结题公式:泰勒公式,我们用它可以查出给定的查询日期是星期几。

这个公式推导的过程我就不放出来了,起初我也是能看懂一点的,越看到后面越懵,数学都还给老师了。

蔡勒公式百度百科:https://baike.baidu.com/item/%E8%94%A1%E5%8B%92%E5%85%AC%E5%BC%8F/10491767?fr=aladdin

蔡勒公式详细说明:https://www.cnblogs.com/faterazer/p/11393521.html

实现:

复制代码
class Solution {
    public String dayOfTheWeek(int day, int month, int year) {
        String week[] = {  "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday","Saturday"} ;
        if(month < 3){month +=12;year -=1;}  //1、2月当成前一年的13、14月
        int c = year/100;  //世纪,4位年份的前两位
        year = year%100;   //4位年份的后两位
        int index = (c/4 - 2*c + year + year/4 + 13*(month+1)/5 + day - 1 + 210) % 7;  //加210 的意思是加 30*7 这里的数字存在的意义是,为了不让结果是负数,让它加一个7的倍数的大数字,让负数变为正数,且不影响结果
        System.out.println(week[index]);
        return week[index];
    }
}
复制代码

 

posted @   我永远喜欢石原里美  阅读(47)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
点击右上角即可分享
微信分享提示