• B1928 日期差值


     1 /*
     2 题目描述
     3 
     4 有两个日期,求两个日期之间的天数,如果两个日期是连续的,则规定它们之间的天数为两天。
     5 输入格式
     6 
     7 有多组数据,每组数据有两行,分别表示两个日期,形式为YYYYMMDD
     8 输入格式
     9 
    10 每组数据输出一行,即日期差值
    11 样例输入
    12 
    13 20130101
    14 20130105
    15 样例输出
    16 
    17 5
    18 
    19 思路
    20 不妨假设第一个日期早于第二个日期(否则交换即可)
    21 这种求
    22 */
    23 
    24 #include <iostream>
    25 #include <stdio.h>
    26 #include <stdbool.h>
    27 int month[13][2]={ //平年和闰年的每个月的天数
    28 {0, 0}, {31, 31}, {28, 29}, {31, 31}, {30, 30}, {31, 31},{30, 30},
    29 {31, 31}, {31, 31}, {30, 30}, {31, 31}, {30, 30}, {31, 31}
    30 };
    31     bool isLeap(int year){ //判断是否是闰年
    32     return ((year % 4 == 0 && year % 100 != 0) || (year % 400 == 0));
    33     }
    34     int main(){
    35     int time1, y1, m1, d1;
    36     int time2, y2, m2, d2;
    37    while (scanf("%d%d", &time1, &time2) != EOF) {
    38     if (time1 > time2) { //第一个日期晚于第二个日期,则交换
    39     int temp = time1;
    40     time1 = time2;
    41     time2 = temp;
    42     }
    43  y1 = time1 / 10000, m1 = time1 % 10000 / 100, d1 = time1 % 100;
    44  y2 = time2 / 10000, m2 = time2 % 10000 / 100, d2 = time2 % 100;
    45  int ans = 1; //记录结果
    46 //即!((y1 == y2)) && (m1 == m2) && (d1 == d2))
    47 while (y1 < y2 || m1 < m2 || d1 < d2) {
    48     d1++; //天数加1
    49 if(d1 == month[m1][isLeap(y1)] + 1){ //满当月天数
    50     m1++; //日期变为下个月的1号
    51     d1 = 1;
    52     }
    53 if (m1 == 13) { //月份满12个月
    54     y1++; //日期变为下一年的1月
    55     m1 = 1;
    56             }
    57     ans++; //累计
    58         }
    59 printf("%d
    ", ans); //输出结果
    60     }
    61 return 0;
    62 }
  • 相关阅读:
    由前序和中序遍历结果构建二叉树
    Java学习笔记数组与ArrayList
    Java学习笔记字符串
    Java学习笔记关于默认类型或访问权限的总结
    javascript学习笔记之事件和事件处理
    2010年2月1日学习笔记
    Web.config保存整个站点的设置
    ANT的十五大最佳实践
    配置ajaxToolkit的方法【转】
    Java学习笔记Iterator迭代器(Ps.instanceof的用法)
  • 原文地址:https://www.cnblogs.com/z-712/p/7324037.html
Copyright © 2020-2023  润新知