leetcode 每日一题 2023年12月30日 一周中的第几天

题目

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

输入为三个整数:daymonthyear,分别表示日、月、年。

您返回的结果必须是这几个值中的一个 {"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"

提示:

  • 给出的日期一定是在 19712100 年之间的有效日期。

分析

  1. 给出一个日期包含year,month,day现在要求是星期几。

  2. 首先需要找到起始的那天是星期几,
    然后算出给出来的日期距离那天有多少天,
    然后根据算出天数差距,除以一个星期7天看余数,得到是星期几。

  3. 根据提示,给出的日期范围是在1971到2100之间,那么我们直接去看一下1971年1月1日,是星期几。是星期五(Friday)。
    leetcode 每日一题 2023年12月30日 一周中的第几天_第1张图片

  4. 如何计算year-month-day距离1971年1月1日有多少天,只需要计算这中间的每一年有多少天,再加上当前年经历的天数即可。

  5. 最后对7取模即可得到当前是星期几。

代码

class Solution {
   String [] week = {"Friday", "Saturday","Sunday", "Monday", "Tuesday", "Wednesday", "Thursday"};
    int [] monDay = {31,28,31,30,31,30,31,31,30,31,30,31};
    public String dayOfTheWeek(int day, int month, int year) {
        //公元年份为4的倍数但非100的倍数,公元年份为400的倍数
        int total = day;
        for (int i = 1971; i <=year-1 ; i++) {
            int dayYear = 365;
            //判断以前的年有没有闰年
            if(isLeapYear(i)){
                dayYear = 366;
            }
            total+=dayYear;
        }
        //判断当年是否是闰年
        if(isLeapYear(year)){
            monDay[1] = 29;
        }
        for (int i = 0; i < month-1 ; i++) {
            total+=monDay[i];
        }
        return week[(total-1)%7];
    }

    public boolean isLeapYear(int year){
        return (year%4==0&&year%100!=0)||year%400==0;
    }
}

交流

leetcode 每日一题 2023年12月30日 一周中的第几天_第2张图片

你可能感兴趣的:(leetcode每日一题,leetcode,linux,算法)