Java函数2:计算两个日期相差的天数

import java.util.Scanner;
public class HelloWorld {
	public static void main(String[] args){
	//	Scanner s = new Scanner(System.in);
	//	System.out.println("请输入一个数字");
	//	int num = s.nextInt();
		int SUM = Caluater_date_sub_day(2009,1,25,2008,1,10);
		System.out.println(SUM);
	}
	//判断闰年平年
	public static boolean isLeap(int y){
		if((y % 4 == 0 && y % 100 != 0) || y % 400 == 0)
			return true ;
		return false ;
	}
	//判断一年已经过了多少天
	public static int GetDay(int y , int m , int d){
		int sum = 0 ;
		switch(m){
		case 12 : sum += 31 ;
		case 11 : sum += 30 ;
		case 10 : sum += 31 ;
		case 9  : sum += 30 ;
		case 8  : sum += 31 ;
		case 7  : sum += 31 ;
		case 6  : sum += 30 ;
		case 5  : sum += 31 ;
		case 4  : sum += 30 ;
		case 3  : sum += 31 ;
		case 2  :
				if(isLeap(y) == true)
					sum += 29 ;
				else
					sum += 28 ;
		case 1  : sum += 31 ;
		sum += d ;
		}
		return d ;
	}
	//判断一年还剩下多少天
	public static int OthearDay(int y , int m , int d)
	{
		if(isLeap(y) == true)
		   return 366 - GetDay(y , m , d);
		return 365 - GetDay(y, m, d) ;
	}
	//判断两个日期相差的天数
	public static int Caluater_date_sub_day(int y1,int m1,int d1,int y2,int m2 ,int d2)
	{
		if(y1 == y2){
			int day1 = GetDay(y1, m1, d1) - GetDay(y2, m2, d2) ;
			return abs(day1);
		}
		else if(y1 < y2){
			int sum1 = OthearDay(y1, m1, d1) ;
			int sum2 = GetDay(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
		{
			int sum1 = GetDay(y1, m1, d1) ;
			int sum2 = OthearDay(y2, m2, d2) ;
			int sum3 = 0 ;
			for(int i = y2 + 1 ; i < y1 ; i++){
				if(isLeap(i))
					sum3+=366 ;
				else
					sum3+=365 ;
			}
			return sum1+sum2+sum3 ;
		}
	}
	//计算一个数的绝对值
	public static int abs(int num){
		return num > 0 ? num : -num ;
	}
}
时间: 2024-12-05 11:29:57

Java函数2:计算两个日期相差的天数的相关文章

Java 计算两个日期相差的天数

import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; public class test16 { /** * @param args * @throws ParseException */ public static void main(String[] args) throws ParseException { /

利用Java中Calendar计算两个日期之间的天数和周数_java

前言 究竟什么是一个 Calendar 呢?中文的翻译就是日历,那我们立刻可以想到我们生活中有阳(公)历.阴(农)历之分.它们的区别在哪呢? 比如有: 月份的定义 - 阳`(公)历 一年12 个月,每个月的天数各不同:阴(农)历,每个月固定28天 每周的第一天 - 阳(公)历星期日是第一天:阴(农)历,星期一是第一天 实际上,在历史上有着许多种纪元的方法.它们的差异实在太大了,比如说一个人的生日是"八月八日" 那么一种可能是阳(公)历的八月八日,但也可以是阴(农)历的日期.所以为了计时

Excel怎么使用text函数计算两个日期相差的时间?

  Excel怎么使用text函数计算两个日期相差的时间?          1.先新建一个空白表格,重命名"计算两个日期的时间长"; 2.打开表格输入相应的类别标题,如"姓名.出差时间.返回时间.出差时长"; 3.在"姓名.出差时间.返回时间"类别里填入相应的内容; 4.在"D3"单元格输入公式"=TEXT(C3-B3,"[h]:mm:ss")",就会显示相差的时间了; 5.选中&qu

php计算两个日期相差天数的方法

本文实例讲述了php计算两个日期相差天数的方法.分享给大家供大家参考.具体实现方法如下: <?php /** * 求两个日期之间相差的天数 * (针对1970年1月1日之后,求之前可以采用泰勒公式) * @param string $day1 * @param string $day2 * @return number */ function diffBetweenTwoDays ($day1, $day2) { $second1 = strtotime($day1); $second2 = s

分享PHP计算两个日期相差天数的代码_php技巧

本文实例讲述了php计算两个日期相差天数的方法.分享给大家供大家参考.具体实现方法如下: <?php $date1 = date( 'Y-m-d' ); $date2 = "2015-12-04"; $diff = abs(strtotime($date2) - strtotime($date1)); $years = floor($diff / (365*60*60*24)); $months = floor(($diff - $years * 365*60*60*24) /

php计算两个日期相差天数的方法_php技巧

本文实例讲述了php计算两个日期相差天数的方法.分享给大家供大家参考.具体实现方法如下: <?php /** * 求两个日期之间相差的天数 * (针对1970年1月1日之后,求之前可以采用泰勒公式) * @param string $day1 * @param string $day2 * @return number */ function diffBetweenTwoDays ($day1, $day2) { $second1 = strtotime($day1); $second2 = s

c++-求两个日期相差的天数 用友元函数 我不知道要怎么改 看不懂调试。

问题描述 求两个日期相差的天数 用友元函数 我不知道要怎么改 看不懂调试. #include class Date {int yearmonthday;public : void show(); int set(int aint bint c); friend int End(Date &d1 Date &d2);};void Date::show (){cout<<""please input year monthday.""<}

MSSQL 计算两个日期相差的工作天数的语句_MsSql

复制代码 代码如下: if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[f_WorkDay]') and xtype in (N'FN', N'IF', N'TF')) drop function [dbo].[f_WorkDay] GO --计算两个日期相差的工作天数 CREATE FUNCTION f_WorkDay( @dt_begin datetime, --计算的开始日期 @dt_end date

MSSQL 计算两个日期相差的工作天数的语句

复制代码 代码如下: if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[f_WorkDay]') and xtype in (N'FN', N'IF', N'TF')) drop function [dbo].[f_WorkDay] GO --计算两个日期相差的工作天数 CREATE FUNCTION f_WorkDay( @dt_begin datetime, --计算的开始日期 @dt_end date