关于日期的常用算法

关于日期的常用算法有很多,但如果掌握了基本的算法,难一点的可以分解为简单的,各个击破。

1)判断一年是否为闰年:

//判断一年是否为闰年
static boolean IsLeapYear(int year){
    return (year % 400 == 0 || year % 4 == 0 && year % 100 != 0);
}

2)获得某一年的总天数:(闰年366天,非闰年355)

//获得某一年的总天数
static int GetAllDays(int year){
    return (IsLeapYear(year)? 366: 365);
}

3)获得某年、某月的最大天数

//获得某年、某月的最大天数
static int GetMaxDay(int year,int month){
    switch(month)
    {
    case 1:
    case 3:
    case 5:
    case 7:
    case 8:
    case 10:
    case 12:
        return 31;        
    case 4:
    case 6:
    case 9:
    case 11:
        return 30;    
    case 2:
        return (IsLeapYear(year)? 29: 28);    
    default:
        return -1;
    }
}


4)获得某年、某月、某日是这一年的第几天

//获得某年、某月、某日是这一年的第几天
static int GetDays(int year,int month,int day){
    int sum = 0;
    
    for(int i = 1; i < month ; i++){
        sum += GetMaxDay(year,i);
    }
    
    return sum+day;
}

5)获得某年某月的下一天

//获得某年某月某日的下一天
static void GetNextDay(int year,int month,int day){
    if(day != GetMaxDay(year,month)){
        day++;
    }else
    {
        if(month != 12)
        {month++; day = 1;}
        else
        {year++; month = day =1;}
    }
}

6)获得某年某日的前一天

//获得某年某月某日的前一天
static void GetPreDay(int year,int month,int day){
    if(day != 1){
        day--;
    }else{
        if(month != 1){
            month--;
            GetMaxDay(year,month);
        }
        else{
            year--;month = 12;day = 31;
        }
    }
}

7)获得某年某月某日n天后的日期

//获得某年某月某日n天之后的日期
static void GetXDay(int year,int month,int day,int X){
    for(int i = 1; i<= X; i++){
        if(day != GetMaxDay(year,month)){
            day++;
        }else{
            if(month != 12){
                month++;day = 1;
            }else{
                year++;
                month = day = 1;
            }
        }
    }
    System.out.println(X+" 天后是:"+year+"-"+month+"-"+day);
    
    
}

8)比较日期大小

//比较日期大小
static int CompareDay(int year1,int month1,int day1, int year2,int month2,int day2){
    return year1 != year2? (year1-year2):(month1 != month2 ? (month1-month2): day1-day2);
}

9)求日期之差

//求日期之差
static int GetDateDiff1(int year1,int month1,int day1,int year2,int month2,int day2){
    int sum = GetAllDays(year1) - GetDays(year1,month1,day1);
    for(int i = year1+1; i < year2; i++ ){
        sum += GetAllDays(i);
    }
    sum += GetDays(year2,month2,day2);
    return sum;
}
static int GetDateDiff(int year1,int month1,int day1,int year2,int month2,int day2){
    if(CompareDay(year1,month1,day1,year2,month2,day2) > 0){
        return -GetDateDiff1(year2,month2,day2,year1,month1,day1);
    }else if(CompareDay(year1,month1,day1,year2,month2,day2) < 0){
        return GetDateDiff1(year1,month1,day1,year2,month2,day2);
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值