和日期相关的代码和bug——一道力扣题中的小发现
目录
Day of the Week
题目大意
常规方法
Python代码
Golang代码
C++代码
基姆拉尔森公式
Python代码
Golang代码
C++代码
使用库函数
Python代码
Golang代码
C++代码
Day of the Week
Given a date, return the corresponding day of the week for that date.
The input is given as three integers representing the day , month and year respectively.
Return the answer as one of the following values {"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"} .
Example 1:
Input: day = 31, month = 8, year = 2019
Output: "Saturday"
Example 2:
Input: day = 18, month = 7, year = 1999
Output: "Sunday"
Example 3:
Input: day = 15, month = 8, year = 1993
Output: "Sunday"
题目大意
给你一个日期,请你设计一个算法来判断它是对应一周中的哪一天。
输入为三个整数: day、 month 和 year,分别表示日、月、年。
您返回的结果必须是这几个值中的一个 {"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday",
"Friday", "Saturday"}。
提示:
给出的日期一定是在 1971 到 2100 年之间的有效日期。
解题思路:
给出一个日期,要求算出这一天是星期几。
常规方法
从1971.1.1起,先累计整年year、整月month-1的天数,再加上最后一个月month的天数day,然后总天数减1后与7求余。最后得到的余数在星期字串数组中位置索引,显然前提要知道1971.1.1这个基准日期是星期几,再作一个索引位移就是答案。
另外常规方法还需要判断year是否闰年,规则:y%4==0 and y%100!=0 or y%400==0,据说是1582
Python代码
python代码非常简单,不需另外导入库只用内置函数就能搞定。
class Solution(object):def DayOfWeek(self, year, month, day):days = 0isLeapYear = lambda y:y%4==0 and y%100!=0 or y%400==0monthday = [31,28,31,30,31,30,31,31,30,31,30,31]week = ["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"]monthday[1] = 29 if isLeapYear(year) else 28for i in range(1971,year):days += 366 if isLeapYear(i) else 365days += sum(monthday[:month-1], day-1)return week[(days+5)%7]if __name__ == "__main__":s = Solution()print(s.DayOfWeek(2019,8,31))print(s.DayOfWeek(1999,7,18))print(s.DayOfWeek(1993,8,15))print(s.DayOfWeek(1971,6,12))print(s.DayOfWeek(2023,2,22))print(s.DayOfWeek(2040,6,13))
输出:
Saturday
Sunday
Sunday
Saturday
Wednesday
Wednesday
Golang代码
基本原理相同,另外自定义一个数组求和公式即可。
package mainimport "fmt"func DayOfWeek(year int, month int, day int) string {days := 0isLeapYear := func(y int) bool {return y%4 == 0 && y%100 != 0 || y%400 == 0}Sum := func(nums []int, initNum int) int {var sumNum int = 0for _, num := range nums {sumNum += num}return sumNum + initNum}monthday := []int{31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}week := []string{"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"}if isLeapYear(year) {monthday[1] = 29} else {monthday[1] = 28}for i := 1971; i < year; i++ {if isLeapYear(i) {days += 366} else {days += 365}}days += Sum(monthday[:month-1], day-1)return week[(days+5)%7]
}func main() {fmt.Println(DayOfWeek(2019, 8, 31))fmt.Println(DayOfWeek(1999, 7, 18))fmt.Println(DayOfWeek(1993, 8, 15))fmt.Println(DayOfWeek(1971, 6, 12))fmt.Println(DayOfWeek(2023, 2, 22))fmt.Println(DayOfWeek(2040, 6, 13))}
输出:
Saturday
Sunday
Sunday
Saturday
Wednesday
Wednesday
成功: 进程退出代码 0.
C++代码
引入C++11的容器vector,可以省掉最后一个非整年的各月份日数循环累加,只要用<numeric>库中的函数accumulate,方便累加非整年的各月份日数,并且把day作为基准数一并累加掉。
#include<iostream>
#include<vector>
#include<numeric>
using namespace std;class Solution
{
public:string DayOfWeek(int year, int month, int day){int days = 0;auto isLeapYear = [](int y) { return y%4==0 && y%100!=0 || y%400==0; };vector<int> monthday = {31,28,31,30,31,30,31,31,30,31,30,31};vector<string> week = {"Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"};monthday[1] = isLeapYear(year) ? 29 : 28;for (int i=1971;i<year;i++)days += isLeapYear(i) ? 366 : 365;days += accumulate(monthday.begin(), monthday.begin()+month-1, day-1);return week[(days+5)%7];}
};int main()
{Solution s;cout << s.DayOfWeek(2019,8,31) << endl;cout << s.DayOfWeek(1999,7,18) << endl;cout << s.DayOfWeek(1993,8,15) << endl;cout << s.DayOfWeek(1971,6,12) << endl;cout << s.DayOfWeek(2023,2,22) << endl;cout << s.DayOfWeek(2040,6,13) << endl;return 0;
}
Dev C++ 6.3 编译通过:
Saturday
Sunday
Sunday
Saturday
Wednesday
Wednesday--------------------------------
Process exited after 0.02175 seconds with return value 0
请按任意键继续. . .
基姆拉尔森公式
万能的日期计算公式,不用知道基准日是哪一天,也不需要判断year是否为闰年。
公式:weekday = (day+2month+3(month+1)/5+year+year/4-year/100+year/400+1)%7
注意:1月和2月需看做上一年的13月与14月,即 month<3时, year-=1; month+=12
Python代码
class Solution(object):def DayOfWeek(self, year, month, day):week = ["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"]if month<3: year, month = year-1, month+12weekday = (day+2*month+3*(month+1)//5+year+year//4-year//100+year//400+1)%7return dict(zip(range(7),week)).get(weekday)if __name__ == "__main__":s = Solution()print(s.DayOfWeek(2019,8,31))print(s.DayOfWeek(1999,7,18))print(s.DayOfWeek(1993,8,15))print(s.DayOfWeek(1971,6,12))print(s.DayOfWeek(2023,2,22))print(s.DayOfWeek(2040,6,13))
Golang代码
package mainimport "fmt"func DayOfWeek(year int, month int, day int) string {week := []string{"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"}if month < 3 {year -= 1month += 12}weekday := (day + 2*month + 3*(month+1)/5 + year + year/4 - year/100 + year/400 + 1) % 7return week[weekday]
}func main() {fmt.Println(DayOfWeek(2019, 8, 31))fmt.Println(DayOfWeek(1999, 7, 18))fmt.Println(DayOfWeek(1993, 8, 15))fmt.Println(DayOfWeek(1971, 6, 12))fmt.Println(DayOfWeek(2023, 2, 22))fmt.Println(DayOfWeek(2040, 6, 13))}
C++代码
#include<iostream>
using namespace std;class Solution
{
public:string DayOfWeek(int year, int month, int day){const char *week[7] = {"Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"};if (month < 3) {year -= 1;month += 12;} int weekday = (day+2*month+3*(month+1)/5+year+year/4-year/100+year/400+1)%7;return week[weekday];}
};int main()
{Solution s;cout << s.DayOfWeek(2019,8,31) << endl;cout << s.DayOfWeek(1999,7,18) << endl;cout << s.DayOfWeek(1993,8,15) << endl;cout << s.DayOfWeek(1971,6,12) << endl;cout << s.DayOfWeek(2023,2,22) << endl;cout << s.DayOfWeek(2040,6,13) << endl;return 0;
}
使用库函数
Python代码
datetime库
import datetimeclass Solution(object):def DayOfWeek(self, year, month, day):week = ["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"]weekday = datetime.date(year,month,day).isoweekday()return week[weekday%7]if __name__ == "__main__":s = Solution()print(s.DayOfWeek(2019,8,31))print(s.DayOfWeek(1999,7,18))print(s.DayOfWeek(1993,8,15))print(s.DayOfWeek(1971,6,12))print(s.DayOfWeek(2023,2,22))print(s.DayOfWeek(2040,6,13))
calendar库
import calendarclass Solution(object):def DayOfWeek(self, year, month, day):week = ["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"]weekday = calendar.weekday(year,month,day)+1return week[weekday%7]if __name__ == "__main__":s = Solution()print(s.DayOfWeek(2019,8,31))print(s.DayOfWeek(1999,7,18))print(s.DayOfWeek(1993,8,15))print(s.DayOfWeek(1971,6,12))print(s.DayOfWeek(2023,2,22))print(s.DayOfWeek(2040,6,13))
Golang代码
time库,超级省事,连星期数组都不用了。
package mainimport ("fmt""time"
)func DayOfWeek(year int, month int, day int) string {return time.Date(year, time.Month(month), day, 0, 0, 0, 0, time.Local).Weekday().String()
}func main() {fmt.Println(DayOfWeek(2019, 8, 31))fmt.Println(DayOfWeek(1999, 7, 18))fmt.Println(DayOfWeek(1993, 8, 15))fmt.Println(DayOfWeek(1971, 6, 12))fmt.Println(DayOfWeek(2023, 2, 22))fmt.Println(DayOfWeek(2040, 6, 13))}
C++代码
ctime库
#include<iostream>
#include<ctime>
using namespace std;class Solution
{
public:string DayOfWeek(int year, int month, int day){const char *week[7] = {"Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"};struct tm t = {0};t.tm_year = year - 1900;t.tm_mon = month - 1;t.tm_mday = day;mktime(&t);return week[t.tm_wday%7];}
};int main()
{Solution s;cout << s.DayOfWeek(2019,8,31) << endl;cout << s.DayOfWeek(1999,7,18) << endl;cout << s.DayOfWeek(1993,8,15) << endl;cout << s.DayOfWeek(1971,6,12) << endl;cout << s.DayOfWeek(2023,2,22) << endl;cout << s.DayOfWeek(2040,6,13) << endl;return 0;
}
输出:
Saturday
Sunday
Sunday
Saturday
Wednesday
Sunday--------------------------------
Process exited after 0.02402 seconds with return value 0
请按任意键继续. . .
发现没? 2040.6.13返回的星期是错的!
网上查了资料,原来ctime库的CTime对象是有指定范围的:
static CTime WINAPI GetCurrentTime( );
获取系统当前日期和时间。返回表示当前日期和时间的CTime对象。
int GetYear( ) const;
获取CTime对象表示时间的年份。范围从1970年1月1日到2038年1月18日。
时间范围测试:
#include<iostream>
#include<ctime>
using namespace std;class Solution
{
public:string DayOfWeek(int year, int month, int day){const char *week[7] = {"Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"};struct tm t = {0};t.tm_year = year - 1900;t.tm_mon = month - 1;t.tm_mday = day;mktime(&t);return week[t.tm_wday%7];}
};int main()
{Solution s;for (int i=16;i<25;i++)cout << i << ":" << s.DayOfWeek(2038,1,i) << endl;return 0;
}
测试结果:
16:Saturday
17:Sunday
18:Monday
19:Tuesday
20:Sunday
21:Sunday
22:Sunday
23:Sunday
24:Sunday--------------------------------
Process exited after 0.05159 seconds with return value 0
请按任意键继续. . .
2038.1.19日的星期也对,之后的全部返回Sunday。
修改这个问题,技术上一点问题都没有。 目前C++都发展到C++20了,而我用的是C++11,暂不知道之后版本的库文件有没有对此问题作过更新。那么,问题来了:
之前用C语言写的的软件,用ctime或者time.h获取时间的软件在2038年1月19日之后都会发生错误。还好,还有整整15年时间来改正这个“时间Bug”。
相关文章:
和日期相关的代码和bug——一道力扣题中的小发现
目录 Day of the Week 题目大意 常规方法 Python代码 Golang代码 C代码 基姆拉尔森公式 Python代码 Golang代码 C代码 使用库函数 Python代码 Golang代码 C代码 Day of the Week Given a date, return the corresponding day of the week for that date. The inp…...
如何在2023年学习编程并获得开发者工作
丢下自负 许多进入软件开发领域的人都是从最底层开始的,你可能会获得“初级开发者”的头衔。每天面临的问题是:我有十年的专业经验了。我不是个入门员工。但尽管过去的工作经验丰富,我仍然是个入门级的开发者,我还是个新手。别总…...
Python实战之小说下载神器(三)排行榜所有小说:最全热门小说合集,总有一款适合你,好多好多好多超赞的小说...(源码分享学习)
前言 这次的是一个系列内容 给大家讲解一下何一步一步实现一个完整的实战项目案例系列之 小说下载神器(三)(GUI界面化程序) 多线程采集小说下载、采集排行榜所有小说 哈喽!大家上午好啦,我是爱看小说的栗子…...
前端监控之用户行为监控实践1(数据收集)
前文对前端监控进行了简单介绍,起因是因为当前做的一个需求,老板要看当前项目的uv、pv信息。其实这是非常简单的统计。 但在最开始接到这个需求,却难倒我了。 现在进行简单的复盘,记录一下实现方法。 一、数据记录 用户行为从大…...
【网络原理7】认识HTTP
目录 一、HTTP协议的位置 二、HTTP协议的特点&应用场景 三、HTTP协议的格式的查看 Fiddler下载与使用 编辑 如何查看HTTP请求消息 编辑 如何查看HTTP响应数据包 如何默认开启HTTPS的解析功能 四、HTTP的请求数据包的格式含义 第一部分:请求行&…...
SPI实验
目录 一、SPI 简介 二、硬件原理 ECSPI3_SCLK ECSPI3_MISO和ECSPI3_MOSI ECSPI3_SS0 三、I.MX6U ECSPI 简介 ECSPIx_RXDATA ECSPIx_TXDATA ECSPIx_CONREG ECSPIx_CONFIGREG ECSPIx_PERIODREG编辑 ECSPIx_STATREG 四、ICM-20608 简介 五、代码编写 1、创建文件及文…...
去基线处理
目录detrend函数去除基线多项式拟合原函数BEADS 基线处理小波算法经验模态分解(EMD)参考detrend函数去除基线 detrend函数只能用于去除线性趋势,对于非线性的无能为力。 函数表达式:y scipy.signal.detrend(x): 从信号中删除线…...
模拟信号4-20mA /0-5V/0-75mV/0-100mV转RS-485/232,数据采集A/D转换模块 YL21
特点:● 模拟信号采集,隔离转换 RS-485/232输出● 采用12位AD转换器,测量精度优于0.1%● 通过RS-485/232接口可以程控校准模块精度● 信号输入 / 输出之间隔离耐压3000VDC ● 宽电源供电范围:8 ~ 32VDC● 可靠性高,编程…...
[USB]键盘数据格式以及按键键值
USB键盘数据包含8个字节 BYTE1 – 特殊按键 |–bit0: Left Control是否按下,按下为1 |–bit1: Left Shift 是否按下,按下为1 |–bit2: Left Alt 是否按下,按下为1 |–bit3: Left GUI(Windows键) 是否按下,…...
web客户端-websocket
1、websocket简介 WebSocket是HTML5开始提供的一种在单个TCP连接上进行全双工通讯的协议。 WebSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在WebSocket API中,浏览器和服务器只需要完成一次握手,…...
mysql间隙锁
首先我们这里有一个表t,其中的数据如下图所示 注意哈 update由于操作的最新的值,所以是当前读! 另外一个事务插入 8的时候发生锁 而我对id为10的数据进行更新,却不会被锁住 分析:在执行当前读时,由于id7不存…...
华为OD机试 - 计算面积(Java) | 机试题+算法思路+考点+代码解析 【2023】
计算面积 绘图机器的绘图笔初始位i在原点(0.0)。 机器启动后其绘图笔按下面规则绘制直线: 1 )尝试沿着横向坐标轴正向绘制直线,直到给定的终点值E, 2 )期间可通过指令在纵坐标轴方向进行偏移。井同时绘制直线,偏移后按规则1绘制直线;指令的格式为X offsetY。表示在横坐标X…...
Python 之 Pandas 时间戳、通过时间间隔实现 datetime 加减、时间转化、时期频率转换和 shift() 时间频率进行移位)
文章目录一、时间戳1. unit 参数是 s2. year、month、day、hour、minute、second、microsecond 单独设置时间二、通过时间间隔实现 datetime 加减三、时间转化1. 处理各种输入格式2. 将字符串转 datetime3. 除了可以将文本数据转为时间戳外,还可以将 unix 时间转为时…...
一篇文章搞定linux网络模型
网络协议感觉晦涩难懂?什么七层网络模型?又五层网络模型?又四层网络模型?TCP/IP协议是个啥?UDP是啥?什么是三次握手?什么是四次挥手?tcpdump听说是抓包的,怎么用…...
惠普庆祝在中国40年,强化中国发展战略
中国北京,2023年2月23日 ——今日,“品质信赖向未来” 惠普在中国40年系列活动启动仪式及惠普打印春季新品发布会在北京盛大举行。现场,惠普回顾了40年来与中国经济及产业共同发展的历程,并再次强调了惠普一以贯之的“在中国&…...
C++小作业
前言:long long time ago,老大留了点小作业,一直忘了写…偷偷补上 小作业目录unique_ptr vs shared_ptrunique_ptrshared_ptrpublisher/subscriber 1?boost::bindstd::bindthis? _1?TopicContextPtr?std::moveunique_ptr vs sh…...
Python基础 — lambda匿名函数
1、什么是匿名函数? 匿名函数,顾名思义,就是没有名字的函数,它主要用在那些只使用一次的场景中。如果我们的程序中只需要调用一次某个简单逻辑,把它写成函数还需要先定义、取函数名字等一些列操作,这种场景…...
MongoDB安装和使用过程常见问题
文章目录一、安装过程显示没有相应的权限二、pymongo无法使用,报错一、安装过程显示没有相应的权限 oh我的天,找了网上很多种方法都不行哈哈 不同的电脑对应不同的问题吧~ 我的这个问题是这样解决滴 先直接简述操作路径,不明白的可以看如下图…...
AWS攻略——使用中转网关(Transit Gateway)连接同区域(Region)VPC
文章目录环境准备创建VPC配置中转网关给每个VPC创建Transit Gateway专属挂载子网创建中转网关创建中转网关挂载修改VPC的路由验证创建业务Private子网创建可被外网访问的环境测试子网连通性Public子网到Private子网Private子网到Private子网知识点参考资料在《AWS攻略——Peeri…...
Rouge | 自动文摘及机器翻译评价指标
tag:评价指标,摘要,nlp Rouge(Recall-Oriented Understudy for Gisting Evaluation),是评估自动文摘以及机器翻译的一组指标。它通过将自动生成的摘要或翻译与一组参考摘要(通常是人工生成的)进行比较计算,得出相应的分值&#x…...
深入浅出Asp.Net Core MVC应用开发系列-AspNetCore中的日志记录
ASP.NET Core 是一个跨平台的开源框架,用于在 Windows、macOS 或 Linux 上生成基于云的新式 Web 应用。 ASP.NET Core 中的日志记录 .NET 通过 ILogger API 支持高性能结构化日志记录,以帮助监视应用程序行为和诊断问题。 可以通过配置不同的记录提供程…...
边缘计算医疗风险自查APP开发方案
核心目标:在便携设备(智能手表/家用检测仪)部署轻量化疾病预测模型,实现低延迟、隐私安全的实时健康风险评估。 一、技术架构设计 #mermaid-svg-iuNaeeLK2YoFKfao {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg…...
MMaDA: Multimodal Large Diffusion Language Models
CODE : https://github.com/Gen-Verse/MMaDA Abstract 我们介绍了一种新型的多模态扩散基础模型MMaDA,它被设计用于在文本推理、多模态理解和文本到图像生成等不同领域实现卓越的性能。该方法的特点是三个关键创新:(i) MMaDA采用统一的扩散架构…...
跨链模式:多链互操作架构与性能扩展方案
跨链模式:多链互操作架构与性能扩展方案 ——构建下一代区块链互联网的技术基石 一、跨链架构的核心范式演进 1. 分层协议栈:模块化解耦设计 现代跨链系统采用分层协议栈实现灵活扩展(H2Cross架构): 适配层…...
Neo4j 集群管理:原理、技术与最佳实践深度解析
Neo4j 的集群技术是其企业级高可用性、可扩展性和容错能力的核心。通过深入分析官方文档,本文将系统阐述其集群管理的核心原理、关键技术、实用技巧和行业最佳实践。 Neo4j 的 Causal Clustering 架构提供了一个强大而灵活的基石,用于构建高可用、可扩展且一致的图数据库服务…...
Web 架构之 CDN 加速原理与落地实践
文章目录 一、思维导图二、正文内容(一)CDN 基础概念1. 定义2. 组成部分 (二)CDN 加速原理1. 请求路由2. 内容缓存3. 内容更新 (三)CDN 落地实践1. 选择 CDN 服务商2. 配置 CDN3. 集成到 Web 架构 …...
Redis的发布订阅模式与专业的 MQ(如 Kafka, RabbitMQ)相比,优缺点是什么?适用于哪些场景?
Redis 的发布订阅(Pub/Sub)模式与专业的 MQ(Message Queue)如 Kafka、RabbitMQ 进行比较,核心的权衡点在于:简单与速度 vs. 可靠与功能。 下面我们详细展开对比。 Redis Pub/Sub 的核心特点 它是一个发后…...
iview框架主题色的应用
1.下载 less要使用3.0.0以下的版本 npm install less2.7.3 npm install less-loader4.0.52./src/config/theme.js文件 module.exports {yellow: {theme-color: #FDCE04},blue: {theme-color: #547CE7} }在sass中使用theme配置的颜色主题,无需引入,直接可…...
在鸿蒙HarmonyOS 5中使用DevEco Studio实现企业微信功能
1. 开发环境准备 安装DevEco Studio 3.1: 从华为开发者官网下载最新版DevEco Studio安装HarmonyOS 5.0 SDK 项目配置: // module.json5 {"module": {"requestPermissions": [{"name": "ohos.permis…...
django blank 与 null的区别
1.blank blank控制表单验证时是否允许字段为空 2.null null控制数据库层面是否为空 但是,要注意以下几点: Django的表单验证与null无关:null参数控制的是数据库层面字段是否可以为NULL,而blank参数控制的是Django表单验证时字…...
