码迷,mamicode.com
首页 > 其他好文 > 详细

计算两个日期相隔天数 思路:假设1998-10-10 2010-5-5 首先获取1889-10-10这个日期在这一年中还剩多少天 再次获取2010-5-5这个日子在这一年内已经过了

时间:2015-03-30 11:21:17      阅读:139      评论:0      收藏:0      [点我收藏+]

标签:

class FunDemo6 

{

public static void main(String[] args) 

{

//测试函数getDays

//System.out.println(getDays(1992,4,20));

     System.out.println(subDays(1999,1,5,2001,3,10));

}

//判断是否为闰年

public static boolean isLeap (int y) 

{

if(y%4==0&&y%100!=0||y%400==0)

return true;

else

return false;

}

//获取这一年已经过了多少天

public static int getDays(int y,int m,int d) 

{

int sum=0;

switch(m-1){

case 11:sum=sum+30;

        case 10:sum=sum+31;

        case 9:sum=sum+30;

        case 8:sum=sum+31;

case 7:sum=sum+31;

case 6:sum=sum+30;

case 5:sum=sum+31;

case 4:sum=sum+30;

    case 3:sum=sum+31;

    case 2:if(isLeap(y))//一个函数调用了另外一个函数

       sum+=29;//函数不能嵌套声明

       else

   sum+=28;

        case 1:sum=sum+31; 

 

}

return sum+d;

}

//写一个函数,计算这个日期在这一年中还剩多少天

    public static int otherDays(int y,int m,int d)

{

if(isLeap(y))

       return 366-getDays(y,m,d);

else//可以省略

       return 365-getDays(y,m,d);

}

//直接写一个函数,计算两个日期之间相隔的天数

public static int subDays(int y1,int m1,int d1,int y2,int m2,int d2)

{

if(y1==y2)

{

          int days1=getDays(y1,m1,d1)-getDays(y2,m2,d2);

  return abs(days1);

}

else if(y1<y2)

{

  //小的年份剩下的+大的年已经过的+中间年

  int sum1=otherDays(y1,m1,d1);

  int sum2=getDays(y2,m2,d2);

  int sum3=0;

  for(int i=y1+1;i<y2;i++)

  {

  if(isLeap(i))

         sum3+=366;

  else

  sum3+=365;

  }

          return sum1+sum2+sum3;

}

else//y2>y1

{

          int sum1=otherDays(y1,m1,d1);

  int sum2=getDays(y2,m2,d2);

  int sum3=0;

          for(int i=y2+1;i<y1;i++)

  {

    if(isLeap(i))

sum3+=366;

else 

sum+=365;

  }

        return sum1+sum2+sum3;

}

}

public static int abs(int n){

    return n>=0?n:-n;

}

}

 

计算两个日期相隔天数 思路:假设1998-10-10 2010-5-5 首先获取1889-10-10这个日期在这一年中还剩多少天 再次获取2010-5-5这个日子在这一年内已经过了

标签:

原文地址:http://blog.csdn.net/briup_qiuqiu/article/details/44747227

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!