网站建设外包名词解释,蓝海电商怎么做,企业网站的主要内容,崇左网页设计题目
给你一个日期#xff0c;请你设计一个算法来判断它是对应一周中的哪一天。
输入为三个整数#xff1a;day、month 和 year#xff0c;分别表示日、月、年。
您返回的结果必须是这几个值中的一个 {Sunday, Monday, Tuesday, 请你设计一个算法来判断它是对应一周中的哪一天。
输入为三个整数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 年之间的有效日期。
分析 给出一个日期包含year,month,day现在要求是星期几。 首先需要找到起始的那天是星期几 然后算出给出来的日期距离那天有多少天 然后根据算出天数差距除以一个星期7天看余数得到是星期几。 根据提示给出的日期范围是在1971到2100之间那么我们直接去看一下1971年1月1日是星期几。是星期五Friday。 如何计算year-month-day距离1971年1月1日有多少天只需要计算这中间的每一年有多少天再加上当前年经历的天数即可。 最后对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;}totaldayYear;}//判断当年是否是闰年if(isLeapYear(year)){monDay[1] 29;}for (int i 0; i month-1 ; i) {totalmonDay[i];}return week[(total-1)%7];}public boolean isLeapYear(int year){return (year%40year%100!0)||year%4000;}
}交流