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]; } }
本文来自博客园,作者:我永远喜欢石原里美,转载请注明原文链接:https://www.cnblogs.com/yuan-zhou/p/15763757.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义