关闭

计算任意两个日期之间的天数问题

330人阅读 评论(0) 收藏 举报

 程序代码:

#include "stdio.h"

int days[2][13]={365,31,28,31,30,31,30,31,31,30,31,30,31,
                
366,31,29,31,30,31,30,31,31,30,31,30,31}
;

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


int Deal(int dat0,int dat1)
{
    
int i,temp,sum0,sum;
    
int year0,month0,day0,year1,month1,day1;
    sum0 
= sum = 0;
    year0 
= dat0/10000;    month0 = dat0/100%100;    day0 = dat0%100;
    year1 
= dat1/10000;    month1 = dat1/100%100;    day1 = dat1%100;

    
/*************************************************************/
    
/* 在起始日期和终止日期在同一年                                         */
    
/*************************************************************/
    
if((year1-year0)==0)
    
{
        
if((month1-month0)==0)
            
return (day1-day0);
        
else
        
{
            temp 
= Leap(year0);
            sum 
= days[temp][month0] - day0 +1;
            
for(i=month0+1;i<=month1-1;i++)
                sum 
= sum + days[temp][i];
            sum 
=sum + day1;
            
return sum;
        }
        
    }


    
/************************************************************************/
    
/* 在起始日期和终止日期不在同一年                                       */
    
/************************************************************************/
    
//计算开始年剩余的天数
    temp = Leap(year0);
    sum0 
= sum0 + (days[temp][month0] - day0) + 1;
    
for (i=month0+1; i<=12; i++)
        sum0 
= sum0 + days[temp][i];
    
    sum 
= sum +sum0;
    sum0 
= 0;

    
//计算中间年份的总天数
    for (i=year0+1;i<=year1-1;i++)
    
{
        temp 
= Leap(i);
        sum 
= sum + days[temp][0];
    }


    
//计算结束年过去的天数
    temp = Leap(year1);
    
for(i=1;i<=month1-1;i++)
        sum0 
= sum0 + days[temp][i];
    sum0 
= sum0 + day1;

    sum 
= sum + sum0;

    
return sum;
}


void main()
{
    
int dat0,dat1,sum;
    FILE 
*fp = NULL;
    
if(fp = fopen("riqi.dat","r"))
    
{
        
while (fscanf(fp,"%d%d",&dat0,&dat1)==2)
        
{
            
if(dat0==0 && dat1==0)    break;
            sum 
= Deal(dat0,dat1);
            printf(
"天数为:%d ",sum);
        }

    }

    fclose(fp);
}

程序数据文件格式:

(日期格式为:年月日;年为任意位数,月、日的位数为两位,不足补零;两个日期中间以空格隔开;以下数据复制到记事本,重命名为“riqi.dat”,与代码文件放在同一文件夹)

  例:

19861231 19870101
19860101 19861231
19850101 19861231
19840101 19861231
19830101 19861231
19820101 19861231
19810101 19861231
2020811 19860606
0 0

 

运算结果:

天数为:2
天数为:365
天数为:730
天数为:1096
天数为:1461
天数为:1826
天数为:2191
天数为:651528
请按任意键继续. . .

 

0
0

猜你在找
【直播】机器学习&数据挖掘7周实训--韦玮
【套餐】系统集成项目管理工程师顺利通关--徐朋
【直播】3小时掌握Docker最佳实战-徐西宁
【套餐】机器学习系列套餐(算法+实战)--唐宇迪
【直播】计算机视觉原理及实战--屈教授
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之矩阵--黄博士
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之凸优化--马博士
【套餐】Javascript 设计模式实战--曾亮
查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:12006次
    • 积分:342
    • 等级:
    • 排名:千里之外
    • 原创:19篇
    • 转载:0篇
    • 译文:0篇
    • 评论:3条
    文章存档