LeetCode 1360. 日期之间隔几天(闰年判断)
1. 题目
请你编写一个程序来计算两个日期之间隔了多少天。
日期以字符串形式给出,格式为 YYYY-MM-DD
,如示例所示。
示例 1:
输入:date1 = "2019-06-29", date2 = "2019-06-30"
输出:1示例 2:
输入:date1 = "2020-01-15", date2 = "2019-12-31"
输出:15 提示:
给定的日期是 1971 年到 2100 年之间的有效日期。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/number-of-days-between-two-dates
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
2. 解题
- 闰年判断条件:被4整除但不能被100,或者能被400整除
(year%4 == 0 && year%100 != 0) || year%400 == 0
是闰年
class Solution {vector<int> month = {0,31,28,31,30,31,30,31,31,30,31,30,31};
public:int daysBetweenDates(string date1, string date2) {if(date1 == date2)return 0;if(date1 > date2)swap(date1, date2);int days = 0, y1, m1, d1, y2, m2, d2, i;y1 = (date1[0]-'0')*1000+(date1[1]-'0')*100+(date1[2]-'0')*10+date1[3]-'0';m1 = (date1[5]-'0')*10+date1[6]-'0';d1 = (date1[8]-'0')*10+date1[9]-'0';y2 = (date2[0]-'0')*1000+(date2[1]-'0')*100+(date2[2]-'0')*10+date2[3]-'0';m2 = (date2[5]-'0')*10+date2[6]-'0';d2 = (date2[8]-'0')*10+date2[9]-'0';for(i = 1; i < m1; i++)days -= month[i];if(isleapyear(y1) && m1>2)days--;//闰年2月29天days -= d1;for(i = y1; i < y2; ++i)days += isleapyear(i) ? 366 : 365;for(i = 1; i < m2; i++)days += month[i];if(isleapyear(y2) && m2>2)days++;days += d2;return days;}bool isleapyear(int& year){if((year%4 == 0 && year%100 != 0) || year%400 == 0)return true;return false;}
};
LeetCode 1360. 日期之间隔几天(闰年判断)相关推荐
- 1360. 日期之间隔几天 golang
1360. 日期之间隔几天 请你编写一个程序来计算两个日期之间隔了多少天. 日期以字符串形式给出,格式为 YYYY-MM-DD,如示例所示. 示例 1: 输入:date1 = "2019-0 ...
- [leetcode]5169. 日期之间隔几天
不调库 class Solution {public:int daysBetweenDates(string date1, string date2) {int year1 = stoi(date1. ...
- pandas判断日期是否是闰年(is_leap_year)实战: 数据列转化为日期(时间)格式、判断pandas的日期数据列是否是闰年
pandas判断日期是否是闰年(is_leap_year)实战: 数据列转化为日期(时间)格式.判断pandas的日期数据列是否是闰年 目录
- java前台计算date差_js前台计算两个日期的间隔时间
js前台计算两个日期的间隔时间(时间差) 原创 2017年08月28日 16:09:43 标签:javascript 1144 在后台传来两个时间字段,从中解析出两个字符串类型的日期格式 需要在前台解 ...
- java获取两个字符串日期之间间隔的天数
java获取两个字符串日期之间间隔的天数 import java.text.ParseException; import java.text.SimpleDateFormat; import java ...
- excel日期怎么间隔填充_系列或相同日期的自动填充Excel日期
excel日期怎么间隔填充 If you're entering dates on an Excel worksheet, you don't have to enter each date indi ...
- C++判断一个日期是某一年的多少天(含闰年判断)
问题:C++判断一个日期是某一年的多少天(含闰年判断) 本程序通过VC++ 6.0编译与测试,具体代码如下: #include <iostream> using namespace std ...
- 【Excel VBA】用datediff函数计算两个日期的间隔,实例代码亲测好用
纲举目张 说明 代码code 使用说明 说明 前一段时间在CSDN上回答了一位朋友的提问,其中就用到了datediff函数.个人认为这个自带的函数功能很强大,但是了解的人很少,我在最开始写一写功能的时 ...
- android 日期间隔,android-计算两个日期之间间隔的天数
要计算两个日期之间间隔的天数,必须把两个日期转换成统一的时间戳,然后计算其毫秒差,再将毫秒差转换成天数. System.out.print("开始时间:"); String str ...
最新文章
- cocos2d-x 2.0启用HD高清图片支持
- 斯坦福NLP笔记72 —— The Inverted Index
- asp.net 连接 Access 的几种方法
- [bzoj2882]工艺_后缀数组
- python opencv imread()函数 (从文件加载图像)
- html5——DOM扩展
- scala 协变和逆变_Scala方差:协变,不变和逆变
- freemarker java静态方法_java Freemarker页面静态化实例详解
- 面试必会 InnoDB的多版本并发控制(MVCC)
- oracle脑裂复现,Oracle rac集群环境中的特殊问题
- Vivado中常用的几种仿真浅论
- PcShare远程控制(20070722免费版本)发布
- wpsa3版面怎么变成a4、排版不变_怎么把wpsa3转变成a4
- 戴尔计算机进入安全模式后黑屏,电脑进入省电模式黑屏怎么恢复
- 优秀工程师必备的一项技能,你解锁了吗?
- idea 2018.1破解激活方法,有效期至2099年
- 微信开发上传视频到服务器,微信小程序中实现上传视频的开发代码
- AirDisk存宝 【S3\S6简易使用说明】
- 「手把手教你」用Python量化海龟交易法则
- 得数据者得天下!作为后端开发必备技能之一的MySQL,这份十多年经验总结的应用实战与性能调优我想你肯定是需要的!