【每日一题】一周中的第几天

文章目录

Tag

【模拟】【数学】【2023-12-30】


题目来源

1185. 一周中的第几天


解题思路

方法一:模拟

思路

题目中的日期是在 19712100 年之间的有效日期,即 1971-01-012100-12-31 范围内的任意日期。我们需要选定一个标准,将题目中给的日期和这个标准比较来得到给定的日期是一周中的周几。

这个比较的标准选择为 1970-12-31

比较首先需要计算给定的日期距离 1970-12-31 的天数 days,分三部分来计算:

  • 给定的年 year 距离 1970 的年数对天数的贡献,注意每四年就会有闰年出现;
  • 给定的月份之前的月份对天数的贡献,这部分也要考虑闰年对天数的影响;
  • 给定的月份中的天数贡献。

为了方便根据 days 来索引,建立一个数组 weeks = {"Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday"},最后返回 weeks[(day % 7 + 3) % 7] 即可。

算法

在具体实现中,需要判断给定的年份是不是闰年,有以下函数进行判断:

cpp 复制代码
bool isLeapYear(int year) {
	if (year % 400 == 0 || (year % 4 == 0 && year % 100 != 0)) {
			return false;
	}
	return true;
}

提交代码

cpp 复制代码
class Solution {
public:
    string dayOfTheWeek(int day, int month, int year) {
        vector<string> weeks{"Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday"};
        vector<int> months{0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};

        // year 之前的整年的贡献天数
        int days = (year - 1971) * 365 + (year - 1969) / 4; // 这个1969就很妙
        // year年月份的贡献天数
        for(int i = 1; i < month; ++i){
            days += months[i];
        }

        // year 对 day 的贡献天数
        if ((year % 400 == 0 || (year % 4 == 0 && year % 100 != 0)) && month >= 3) {
            days += 1;
        }
        days += day;
        return weeks[(days % 7 + 3) % 7]; // (days % 7 + 3) % 7 化简之后为 (days + 3) % 7
    }
};

复杂度分析

时间复杂度: O ( C ) O(C) O(C),其中 C C C 为一年中的月份数 12。仅需常量时间的数学计算。

空间复杂度: O ( C ) O(C) O(C),其中 C C C 为一年中的月份数 12。仅需常量时间的数学计算。


写在最后

如果您发现文章有任何错误或者对文章有任何疑问,欢迎私信博主或者在评论区指出 💬💬💬。

如果大家有更优的时间、空间复杂度的方法,欢迎评论区交流。

最后,感谢您的阅读,如果有所收获的话可以给我点一个 👍 哦。

相关推荐
大卫小东(Sheldon)1 天前
写了一个BBP算法的实现库,欢迎讨论
数学·rust
救救孩子把2 天前
2-机器学习与大模型开发数学教程-第0章 预备知识-0-2 数列与级数(收敛性、幂级数)
人工智能·数学·机器学习
救救孩子把3 天前
3-机器学习与大模型开发数学教程-第0章 预备知识-0-3 函数初步(多项式、指数、对数、三角函数、反函数)
人工智能·数学·机器学习
HAH-HAH5 天前
【蓝桥杯 2024 国 Java A】粉刷匠小蓝
c++·学习·数学·算法·职场和发展·蓝桥杯·组合数学
hansang_IR7 天前
【题解】洛谷 P4286 [SHOI2008] 安全的航线 [递归分治]
c++·数学·算法·dfs·题解·向量·点积
乔宕一10 天前
留数法分解有理分式
数学
闻缺陷则喜何志丹10 天前
【数论】P10580 [蓝桥杯 2024 国 A] gcd 与 lcm|普及+
c++·数学·蓝桥杯·数论·洛谷
Tisfy11 天前
LeetCode 3516.找到最近的人:计算绝对值大小
数学·算法·leetcode·题解
falomsc11 天前
泊松求和公式推导
数学·数字信号处理·信号与系统·泊松求和
封奚泽优18 天前
数学七夕花礼(MATLAB版)
开发语言·数学·matlab·七夕·鲜花