将两个日期转换成与一个指定日期(例1970-01-01)之间的差然后计算

思路:

两个日期相隔天数的计算,首先可以将两个日期转换成time_t(从指定日期至1970年1月1日0时0分0秒相隔的秒数),然后计算两个time_t的秒数差,最后用此秒数差除以24*3600秒就可以得到相隔的天数。所以程序中需要建立两个函数,一个是将日期转换成time_t的函数,一个是计算日期相隔天数的函数。

例:

1)建立程序的主体结构:

 #include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<time.h>
int get_days(const char* from, const char* to);
time_t convert(int year,int month,int day);
int main()
{
const char* from="2013-3-15";
const char* to="2015-8-14";
int days=get_days(from,to);
printf("From:%s\nTo:%s\n",from,to);
printf("%d\n",days);
system("pause");
return ;
}

get_days函数是计算两个日期相隔天数的主要函数,主要实现从字符串中提取相应的数据和最后差值的计算;convert函数主要是将日期转换成秒值。两个函数的关系是get_day将会调用convert。

2)convert函数的实现:

 time_t convert(int year,int month,int day)
{
tm info={};
info.tm_year=year-;
info.tm_mon=month-;
info.tm_mday=day;
return mktime(&info);
}

这里需要使用的是一个tm的结构体,该结构体包含很多信息,其中最为重要的就是年、月、日、时、分、秒。还有一个重要的内部函数就是mktime该函数可以将tm结构体转换成秒值也就是time_t类型。函数主要实现的方法就是新建一个tm结构体,然后将所有项赋值为0,再将年月日更新入tm结构体,最后使用mktime函数计算秒值并返回。

3)get_days函数的实现:

 int  get_days(const char* from, const char* to)
{
int year,month,day;
sscanf(from,"%d-%d-%d",&year,&month,&day);
int fromSecond=(int)convert(year,month,day);
sscanf(to,"%d-%d-%d",&year,&month,&day);
int toSecond=(int)convert(year,month,day);
return (toSecond-fromSecond)//;
}

这个函数最为重要的就是使用sscanf命令完成字符串中数字部分的获取。一旦获取到年月日再代入函数convert就可计算出秒值,最后将两个秒值相减再除以一天的秒数即可得到结果。

完整程序:

 #include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<time.h>
int get_days(const char* from, const char* to);
time_t convert(int year, int month, int day); int main()
{
const char* from = "2013-3-15";
const char* to = "2015-8-14";
int days = get_days(from, to);
printf("From:%s\nTo:%s\n", from, to);
printf("%d\n", days);
system("pause");
return ;
} time_t convert(int year, int month, int day)
{
tm info = {};
info.tm_year = year - ;
info.tm_mon = month - ;
info.tm_mday = day;
return mktime(&info);
} int get_days(const char* from, const char* to)
{
int year, month, day;
sscanf(from, "%d-%d-%d", &year, &month, &day);
int fromSecond = (int) convert(year, month, day);
sscanf(to, "%d-%d-%d", &year, &month, &day);
int toSecond = (int) convert(year, month, day);
return (toSecond - fromSecond) / / ;
}

直接计算

思路:

比如输入2001/03/23--2013/12/11,分成三段,2001/03/23--2001/12/31,2002年初到2012年底,2013/01/01--2013/12/11.只要判断第二段中是否有闰年即可。

代码:

 //是否闰年
bool IsLeapYear(int y)
{
return ((y%==&&y%!=)||(y%)==);
} //今年已过的天数(从1月1日算起)
int GetNowDays(int y,int m,int d)
{
int days=;
switch(m-)
{
case :
days+=days+;
case :
days+=days+;
case :
days+=days+;
case :
days+=days+;
case :
days+=days+;
case :
days+=days+;
case :
days+=days+;
case :
days+=days+;
case :
days+=days+;
case :
if(IsLeapYear(y))
days+=;
else
days+=;
case :
days+=;
default:
days+=d;
break;
}
return days;
} //今年剩余天数
int GetRemainDays(int y,int m,int d)
{
if(IsLeapYear(y))
return (-GetNowDays(y,m,d));
else
return (-GetNowDays(y,m,d));
} //日期格式为yyyy-mm-dd
//求两个日期之间的相隔天数
int GetExDays(const char* bgDate,const char* exDate)
{
if(bgDate==NULL||exDate==NULL)
return ;
if(strcmp(bgDate,exDate)>)
return ;
int by,bm,bd,ey,em,ed;
int days=;
sscanf(bgDate,"%d-%d-%d",&by,&bm,&bd);
sscanf(exDate,"%d-%d-%d",&ey,&em,&ed); if(ey-by>=)
{
days+=((ey-(by+))/)*(*+);
int tmp=(ey-(by+))%;
for(int i=;i<=tmp;++i)
{
if(IsLeapYear(by+))
days+=;
else
days+=;
}
days+=(GetRemainDays(by,bm,bd)+GetNowDays(ey,em,ed));
}else
{
days+=(GetNowDays(ey,em,ed)-GetNowDays(by,bm,bd));
}
return days;
}

转载请注明出处:http://www.cnblogs.com/fnlingnzb-learner/p/7054503.html

C/C++输入两个任意日期求相隔天数的更多相关文章

  1. ytu 1057: 输入两个整数,求他们相除的余数(带参的宏 + 模板函数 练习)

    1057: 输入两个整数,求他们相除的余数 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 177  Solved: 136[Submit][Status ...

  2. Java计算两个字符串日期之间的天数差

    Java计算两个字符串日期之间的天数差 调用方法: public static void main(String[] args) throws ParseException { String a = ...

  3. javascript中计算两个时间日期间隔的天数

    <script>              /*                  计算两个日期的时间间隔天数              */              //时间字符串的格 ...

  4. 比较两个data日期之间的天数相差

    先将字符串转化为Date类型 转化方式参看:http://blog.csdn.net/caoyinghui1986/archive/2008/04/18/2303570.aspx 然后在调用Date. ...

  5. js-获取两个字符串日期的相隔周

    例如说"2017-04-01 23:00:00"是周六, "2017-04-28 23:00:00"是周五,包含各自所在的那一周,我真正需要获得的结果是5个周. ...

  6. c#(asp.net) 如何计算两个日期之间相隔天数

    1.DateTime t1 = Convert.ToDateTime("2006-1-6"); DateTime t2 = Convert.ToDateTime("200 ...

  7. C#计算两个日期的相隔天数

    DateTime start = Convert.ToDateTime(dateStart.ToShortDateString()); DateTime end = Convert.ToDateTim ...

  8. c++作业:输入两个整数,用函数求两数之和。函数外部声明有什么作用?

    #include <iostream> using namespace std; int main(){ //求两数的和? int a,b,s; cout<<"请你输 ...

  9. 输入两个整数n 和m,从数列1,2,3.......n 中任意取几个数, 使其和等于m ,要求将当中全部的可能组合列出来

    中兴面试题之中的一个.难度系数中. 题目描写叙述例如以下:输入两个整数n 和m,从数列1,2.3.......n 中任意取几个数, 使其和等于m ,要求将当中全部的可能组合列出来. 逻辑分析: 1.比 ...

随机推荐

  1. Dora.Interception: 一个为.NET Core度身定制的AOP框架

    多年从事框架设计开发使我有了一种强迫症,那就是见不得一个应用里频繁地出现重复的代码.之前经常Review别人的代码,一看到这样的程序,我就会想如何将这些重复的代码写在一个地方,然后采用“注入”的方式将 ...

  2. web安全色

    web安全色产生的原因 不同的平台(Mac.PC等)有不同的调色板,不同的浏览器也有自己的调色板.这就意味着对于一幅图,显示在Mac上的Web浏览器中的图像,与它在PC上相同浏览器中显示的效果可能差别 ...

  3. UIView的属性

    .alpha 设置视图的透明度.默认为1. // 完全透明 view.alpha = ; // 不透明 view.alpha = ; .clipsToBounds // 默认是NO,当设置为yes时, ...

  4. c# 操作monogodb的一些简单封装

    public interface IDataBaseCore { } public class BasicData : IDataBaseCore { } public class Filter    ...

  5. c#接口使用详解

    c#接口使用详解 c#中接口隐式与显示实现 c#中接口可以隐式实现.显示实现,隐式实现更常使用.显示实现较少使用 其区别在于 显示实现避免接口函数签名冲突 显示实现只可以以接口形式调用 显示实现其子类 ...

  6. ng-class改变css样式

    而在这所谓的样子当然就是改变其css的属性,而实现能动态的改变其属性值,必然只能是更换其class属性 这里有三种方法: 第一种:通过数据的双向绑定(不推荐) 第二种:通过对象数组 第三种:通过key ...

  7. JSP----获取表单参数

    在页面中可大量使用 request 对象来获取表单域的值,获取表单域的值有如下两个 方法. • String getParamete(String para mN ame): 获取表单域的值. • S ...

  8. EntityFramework6.X之DataAnnotations

    DataAnnotations 在web开发中不仅在客户端需要执行验证逻辑,会对会对用户向表单中输入的数据给出一个即时反馈:且在服务器端也需验证逻辑,因为来自网络的信息都是不能信任的.在MVC中通常是 ...

  9. redis入门指南-第7章-管理

    7.1 持久化 1.RDB方式 2.AOF方式 Redis 持久化: 提供了多种不同级别的持久化方式:一种是RDB,另一种是AOF. RDB 持久化可以在指定的时间间隔内生成数据集的时间点快照(poi ...

  10. javaWeb学习总结(7)-会话之session技术

    什么是Session 使用Cookie和附加URL参数都可以将上一次请求的状态信息传递到下一次请求中,但是如果传递的状态信息较多,将极大降低网络传输效率和增大服务器端程序处理的难度. Session技 ...