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. MVC文件下载和webform也能使用的下载方法

    public ActionResult Index() { DownloadMethod("text/plain", "C:/Users/sunny/Pictures/S ...

  2. Http协议--请求报文和响应报文

           http协议是位于应用层的协议,我们在日常浏览网页比如在导航网站请求百度首页的时候,会先通过http协议把请求做一个类似于编码的工作,发送给百度的服务器,然后在百度服务器响应请求时把相应 ...

  3. z-index、absolute、marquee滚动条的问题

    1.z-index 层次叠加 ,元素叠加,谁的权重大谁就在上面 1).父级出现position:relation:的时候,失效: 2).层叠元素出现float的时候失效: 3).层次元素也得设置pos ...

  4. Mint UI文档

    Mint UI文档:http://elemefe.github.io/mint-ui/#/ 一.Mint UI的安装和基本用法. 1.NPM :npm i mint-ui -S 建议使用npm进行安装 ...

  5. BZOJ3398: [Usaco2009 Feb]Bullcow 牡牛和牝牛(dp)

    题意     约翰要带N(1≤N≤100000)只牛去参加集会里的展示活动,这些牛可以是牡牛,也可以是牝牛.牛们要站成一排.但是牡牛是好斗的,为了避免牡牛闹出乱子,约翰决定任意两只牡牛之间至少要有K( ...

  6. git bash 学习2 --更改url 重置密钥 Permission denied (publickey)问题

    在今天的上传过程中,我意外地遇到了一个问题,,每一次push都会出现 $ git push origin master Permission denied (publickey). fatal: Co ...

  7. build path导入的jar失效导致找不到类

    今天碰到一个很奇葩的问题,搞起我以后都不敢 build path到jar了 所以我就全部放到lib目录下了,因为之前使用build path导入的jar失效了,一直找不类,具体原因我也不清楚,我之前的 ...

  8. Java堆内存又溢出了!教你一招必杀技

    JAVA堆内存管理是影响性能主要因素之一.堆内存溢出是JAVA项目非常常见的故障,在解决该问题之前,必须先了解下JAVA堆内存是怎么工作的. 先看下JAVA堆内存是如何划分的,如图: JVM内存划分为 ...

  9. Python中的正则

    regex_lst = [ ('字符组',), ('非打印字符',), ('特殊字符',), ('定位符',), ('限定符',), ('re模块',), ('分组命名',), ('或匹配',), ( ...

  10. libevent源码分析1 ----evnet相关结构体分析

    位于代码event-internal.h中. event_base类似事件的集合,你创建一个事件,必须将该事件指定一个集合. struct event_base { 50     const stru ...