计算两个日期之间的天数差C++/java
1--Java
分析:调用java中Calendar类
int days(Date date1,Date date2){
Calendar cal = new Calendar.getInstance();
cal.setTime(date1);
int time1 = cal.get(Calendar.DAY_OF_YEAR);
cal.setTime(date2);
int time2 = cal.get(Calendar.DAY_OF_YEAR);
//long days = Math.abs(time1-time2)/(24*3600*1000);
return Math.abs(day1-day2);
}
2--java
int days(Date date1,Date date2){
long time1 = Math.abs(date1.getTime()-date2.getTime());
return (int)time1/(24*3600*1000);
}
分析:首先要知道关于闰年的概念,每四年一润,四百年润,且不能被100整除。因为,闰年二月有29天,全年共计366天。
伪代码:首先将日期字符串的年,月,日分开,类型为yyyy-mm-dd,得到两个日期,year1,month1,day1,year2,month2,day2
如果年份,月份相同:
return day1-day2;(大减小)
如果年份相同,月份不同:
计算date1,该年过了多少天D1;date2,该年过了多少天D2
return D1-D2;
如果,年份不同:
D1=date1 是该年的第多少天
D2=date2距离该年该年结束还有多少天
D3=两个年份之间相差的整年数是多少天
return D1+D2+D
#include <iostream>
using namespace std;
public bool stringToDate(string date,int &year,int &month,int &day){
year = atoi(date.substr(0,4).c_str());
month=atio(date.substr(5,2).c_str());
day=atio(date.substr(8,2).c_str());
Day[12]={31,29,31,30,31,30,31,31,30,31,30,31};
if(isLear(year))
Day[1]=29;
return year>0&&month>0&&month<=12&&day<=Day[month-1];
}
public bool isLeap(int year){
return ((year%4==0)||(year%400==0))&&(year&100!=0);
}
public int daysInYear(int year,int month ,int day){
int days = day;
int Day[12]={31,28,31,30,31,30,31,31,30,31,30,31};
if(isLeap(year))
Day[1]=29;
for(int i=0;i<month-1;i++){
days+=Day[i];
}
return days;
}
public between_days(string date1,string date2){
if(stringToDate(date1,int &year1,int &month1,int &day1)&&stringToDate(string date2,int &year2,int &month2,int &day2)){
if(year1==year2&&month1==month2){
return day1>day2?day1-day2:day2-day1;
}
else if(year1==year2){
int d1 = daysInYear(year1,month1,day1);
int d2 = daysInYear(year2,month2,day2);
return d1>d2?d1-d2:d2-d1;
}
else{
if(year1<year2){
swap(year1,year2);
swap(month1,month2);
swap(day1,day2);
}
int D1=0;
for(int j=year2+1;j<year1;j++){
if(isLeap(j))
D1+=366;
else
D1+=365;
}
int D2=daysInYear(year1,month1,day1);
if(isLeap(year2))
D2=D2+366-daysInYear(year2,month2,day2);
else
D2=D2+365-daysInYear(year2,month2,day2);
return D1+D2;
}
}
}
计算两个日期之间的天数差C++/java的更多相关文章
- As3 计算两个日期之间的天数差
/*日期转YYYYMMDD*/ formDate.fullYear+""+(formDate.month<10?("0"+formDate.month): ...
- JS计算两个日期之间的天数
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- c#后台计算2个日期之间的天数差
/ 计算2个日期之间的天数差 DateTime dt1 = Convert.DateTime("2007-8-1"); DateTime dt2 = Convert.DateTi ...
- iOS 计算两个日期之间的天数问题
//获取当前时间若干年.月.日之后的时间 + (NSDate *)dateWithFromDate:(NSDate *)date years:(NSInteger)years months:(NSIn ...
- java计算两个日期之间的天数,排除节假日和周末
如题所说,计算两个日期之前的天数,排除节假日和周末.这里天数的类型为double,因为该功能实现的是请假天数的计算,有请一上午假的为0.5天. 不够很坑的是每个日期都要查询数据库,感觉很浪费时间. 原 ...
- element ui 日期控件范围时间限制记录、以及计算两个日期之间的天数
日期的筛选经常会有最小的日期选择,例如:当前日期 :clearable="false" :picker-options="pickerOptions0" val ...
- mysql计算两个日期之间的天数
MYSQL自带函数计算给定的两个日期的间隔天数 有两个途径可获得 1.利用TO_DAYS函数 select to_days(now()) - to_days('20120512') 2 ...
- JS计算两个日期之间的天数,时间差计算
1.日期之间的天数计算 //计算天数差的函数,通用 function DateDiff(sDate1, sDate2) { //sDate1和sDate2是2017-9-25格式 var aDate, ...
- JavaScript实现计算两个日期之间的天数
以“yyyy-MM-dd”格式为例,现在有两个日期,分别为“2006-01-01”,“2007-05-20”. 1.调用Date.parser()方法,将字符串格式的时间戳转换为Date类型时间对象: ...
随机推荐
- 如何在SAP云平台上使用MongoDB服务
首先按照我这篇文章在SAP云平台上给您的账号分配MongboDB服务:如何在SAP云平台的Cloud Foundry环境下添加新的Service 然后从这个链接下载SAP提供的例子程序. 1. 使用命 ...
- JavaScript:理解worker事件api
如果你不是很了解Event事件,建议先看我上一篇随文javascript:理解DOM事件.或者直接看下文worker api. hack 首先,我们需要实例一个Worker的对象,浏览器会根据新创建的 ...
- 从.net到java,从基础架构到解决方案。
这一年,职业生涯中的最大变化,是从.net到java的直接跨越,是从平台架构到解决方案的不断完善. 砥砺前行 初出茅庐,天下无敌.再学三年,寸步难行.很多时候不是别人太强,真的是自己太弱,却不自知. ...
- SpringMVC-响应数据和结果视图
返回值分类 1. 字符串 controller 方法返回字符串可以指定逻辑视图名,通过视图解析器解析为物理视图地址. 2. void 在 controller 方法形参上可以定义 request 和 ...
- 【luogu P1783 海滩防御】 题解
题目链接:https://www.luogu.org/problemnew/show/P1783 先把题目改造一下:题目所求是要一条能从0列到n列的路径,使其路径上的最大边长一半最小. 为什么是一半呢 ...
- WinSCP使用与linux命令(小部分命令)
一.下载一个WinSCP WinSCP是一个Windows环境下使用SSH的开源图形化SFTP客户端.同时支持SCP协议.它的主要功能就是在本地与远程计算机间安全的复制文件..winscp也可以链接其 ...
- c++ question 003 求两数大者?
#include <iostream>using namespace std; int main(){ //求两数中的大者? int a,b; cin>>a>>b; ...
- ARC机制中的Strong和weak
什么是ARC Automatic Reference Counting,自动引用计数,即ARC,可以说是WWDC2011和iOS5所引入的最大的变革和最激动人心的变化.ARC是新的LLVM 3.0编译 ...
- EasyUI获取正在编辑状态行的索引
function getRowIndex(target){ var tr = $(target).closest("tr.datagrid-row"); return paseIn ...
- Windows CMD命令 查看无线密码
netsh wlan show profiles netsh wlan show profiles name='无线网络名称' key=clear