【LeeCode】1185. 一周中的第几天 D1

这是一个C++实现的算法,用于根据输入的日期(day、month、year)判断该日期是一周中的哪一天。算法考虑了年份的世纪跳变,并使用了Zeller's congruence公式。最后通过switch-case结构返回对应的星期字符串。

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

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

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

class Solution {
public:
    string dayOfTheWeek(int day, int month, int year) {
       
        int mflag=0;
        int y=year%100;
        int d=day;
        int c=year/100;
         if(month==1 ||month==2){
             if(y%100==0){c--;y=100;}//世纪跳变,此时年会变成99,世纪数-1
             y--;month+=12;}       
         int m=month;
         mflag=c/4-2*c+y+y/4+26*(m+1)/10+d-1+70; 
         //0x年会变成负数,所以加上70,来避免变成负数
         mflag%=7;
         
     switch(mflag){
case 0:return "Sunday";break;
case 1:return"Monday";break;
case 2:return"Tuesday";break;
case 3:return"Wednesday";break;
case 4:return"Thursday";break;
case 5:return"Friday";break;
case 6:return"Saturday";break;
default:return "error";

}
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值