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的更多相关文章

  1. As3 计算两个日期之间的天数差

    /*日期转YYYYMMDD*/ formDate.fullYear+""+(formDate.month<10?("0"+formDate.month): ...

  2. JS计算两个日期之间的天数

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  3. c#后台计算2个日期之间的天数差

    / 计算2个日期之间的天数差 DateTime dt1 = Convert.DateTime("2007-8-1");  DateTime dt2 = Convert.DateTi ...

  4. iOS 计算两个日期之间的天数问题

    //获取当前时间若干年.月.日之后的时间 + (NSDate *)dateWithFromDate:(NSDate *)date years:(NSInteger)years months:(NSIn ...

  5. java计算两个日期之间的天数,排除节假日和周末

    如题所说,计算两个日期之前的天数,排除节假日和周末.这里天数的类型为double,因为该功能实现的是请假天数的计算,有请一上午假的为0.5天. 不够很坑的是每个日期都要查询数据库,感觉很浪费时间. 原 ...

  6. element ui 日期控件范围时间限制记录、以及计算两个日期之间的天数

    日期的筛选经常会有最小的日期选择,例如:当前日期 :clearable="false" :picker-options="pickerOptions0" val ...

  7. mysql计算两个日期之间的天数

    MYSQL自带函数计算给定的两个日期的间隔天数   有两个途径可获得   1.利用TO_DAYS函数   select to_days(now()) - to_days('20120512')   2 ...

  8. JS计算两个日期之间的天数,时间差计算

    1.日期之间的天数计算 //计算天数差的函数,通用 function DateDiff(sDate1, sDate2) { //sDate1和sDate2是2017-9-25格式 var aDate, ...

  9. JavaScript实现计算两个日期之间的天数

    以“yyyy-MM-dd”格式为例,现在有两个日期,分别为“2006-01-01”,“2007-05-20”. 1.调用Date.parser()方法,将字符串格式的时间戳转换为Date类型时间对象: ...

随机推荐

  1. 如何在SAP云平台上使用MongoDB服务

    首先按照我这篇文章在SAP云平台上给您的账号分配MongboDB服务:如何在SAP云平台的Cloud Foundry环境下添加新的Service 然后从这个链接下载SAP提供的例子程序. 1. 使用命 ...

  2. JavaScript:理解worker事件api

    如果你不是很了解Event事件,建议先看我上一篇随文javascript:理解DOM事件.或者直接看下文worker api. hack 首先,我们需要实例一个Worker的对象,浏览器会根据新创建的 ...

  3. 从.net到java,从基础架构到解决方案。

    这一年,职业生涯中的最大变化,是从.net到java的直接跨越,是从平台架构到解决方案的不断完善. 砥砺前行 初出茅庐,天下无敌.再学三年,寸步难行.很多时候不是别人太强,真的是自己太弱,却不自知. ...

  4. SpringMVC-响应数据和结果视图

    返回值分类 1. 字符串 controller 方法返回字符串可以指定逻辑视图名,通过视图解析器解析为物理视图地址. 2. void 在 controller 方法形参上可以定义 request 和 ...

  5. 【luogu P1783 海滩防御】 题解

    题目链接:https://www.luogu.org/problemnew/show/P1783 先把题目改造一下:题目所求是要一条能从0列到n列的路径,使其路径上的最大边长一半最小. 为什么是一半呢 ...

  6. WinSCP使用与linux命令(小部分命令)

    一.下载一个WinSCP WinSCP是一个Windows环境下使用SSH的开源图形化SFTP客户端.同时支持SCP协议.它的主要功能就是在本地与远程计算机间安全的复制文件..winscp也可以链接其 ...

  7. c++ question 003 求两数大者?

    #include <iostream>using namespace std; int main(){ //求两数中的大者? int a,b; cin>>a>>b; ...

  8. ARC机制中的Strong和weak

    什么是ARC Automatic Reference Counting,自动引用计数,即ARC,可以说是WWDC2011和iOS5所引入的最大的变革和最激动人心的变化.ARC是新的LLVM 3.0编译 ...

  9. EasyUI获取正在编辑状态行的索引

    function getRowIndex(target){ var tr = $(target).closest("tr.datagrid-row"); return paseIn ...

  10. Windows CMD命令 查看无线密码

    netsh wlan show profiles netsh wlan show profiles name='无线网络名称' key=clear