KY110 日期差值

KY110 日期差值

⭐️难度:中等(其实简单)

⭐️类型:模拟

📖题目:题目链接

📚题解:

思路:

1、主要问题在处理输入数据,提取出年月日。

2、利用好NextDay函数。

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<vector>  // vector不需要.h
#include<list>
#include<set>  // // 可以用 set 和 multiset
#include<unordered_set> // 可以用 unordered_set 和 unordered_multiset

using namespace std;

void NextDay(int& year, int& month, int& day) {
    int dayOfMonth[] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
    int isLeap;  // 是否是闰年
    if (year % 400 == 0 || (year % 4 == 0 && year % 100 != 0)) {  // 闰年二月29天
        dayOfMonth[2] = 29;
    }
    day++;
    if (day > dayOfMonth[month]) {
        day = 1;
        month++;
    }
    if (month > 12) {
        month = 1;
        year++;
    }
}

int main() {
    int date1 = 0;
    int date2 = 0;

    while (scanf("%d %d", &date1, &date2) != EOF) {
        int year1 = date1 / 10000;
        int year2 = date2 / 10000;
        int month1 = date1 / 100 % 100;
        int month2 = date2 / 100 % 100;
        int day1 = date1 % 100;
        int day2 = date2 % 100;

        int res = 1;
        while (year1 != year2 || month1 != month2 || day1 != day2) {
            NextDay(year1, month1, day1);
            res++;
        }

        printf("%d\n", res);
    }
    return 0;
}

答案:

cpp 复制代码
#include <stdio.h>
#include <string.h>
using namespace std;
void NextDay(int &year, int &month, int &day) {
    // & 出现在定义or形参当中 表示引用的意思 出现在其他位置,表示取地址
    // 存储一下 月份和天数的对应关系
    int dayOfMonth[] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
    int isLeap; // 是否是闰年 
    isLeap = year % 400 == 0 || year % 4 == 0 && year % 100 != 0;
    if (isLeap) {
        dayOfMonth[2] = 29;
    }
    else {
        dayOfMonth[2] = 28;
    }

    ++day;
    if (day > dayOfMonth[month]) {
        day = 1;
        ++month;
    }
    if (month > 12) {
        month = 1;
        ++year;
    }
    //printf("NextDay year = %d, month = %d, day = %d\n", year, month, day);
}
void Swap(int& lhs, int& rhs) {
    int tmp = lhs;
    lhs = rhs;
    rhs = tmp;
}
int main() {
    int date1, date2;
    while (scanf("%d%d", &date1, &date2) != EOF) {
        int year1 = date1 / 10000;
        int year2 = date2 / 10000;
        int mon1 = date1 / 100 % 100;
        int mon2 = date2 / 100 % 100;
        int day1 = date1 % 100;
        int day2 = date2 % 100;

        if (year2 < year1 ||
            year2 == year1 && mon2 < mon1 ||
            year2 == year1 && mon2 == mon1 && day2 < day1) {
            Swap(year2, year1);
            Swap(mon2, mon1);
            Swap(day2, day1);
        }

        int days = 1;
        while (1) {
            if (year1 == year2 && mon1 == mon2 && day1 == day2) {
                break;
            }
            NextDay(year1, mon1, day1);
            ++days;
        }
        printf("%d\n", days);
    }
    return 0;
}
相关推荐
Q741_1471 天前
每日一题 3740. 三个相等元素之间的最小距离 I 3741. 三个相等元素之间的最小距离 II 模拟 哈希表 C++ 题解
c++·算法·leetcode·模拟·数组·哈希表
Q741_1472 天前
每日一题 力扣 3655. 区间乘法查询后的异或 II 模拟 分治 乘法差分法 快速幂 C++ 题解
c++·算法·leetcode·模拟·快速幂·分治·差分法
Q741_1473 天前
每日一题 力扣 3653. 区间乘法查询后的异或 I 模拟 数学 位运算 C++ 题解
c++·数学·算法·leetcode·力扣·模拟
Q741_14710 天前
每日一题 力扣 2751.机器人碰撞 映射 模拟 栈 C++ 题解
算法·leetcode·模拟··映射
A923A13 天前
【洛谷刷题 | 第七天】
算法·模拟·洛谷
浮白载笔的夜晚15 天前
【Virtuoso】PVT工艺角配置问题
学习·模拟·virtuoso
Q741_14715 天前
每日一题 力扣 2946. 循环移位后的矩阵相似检查 力扣 155. 最小栈 数学 数组 模拟 C++ 题解
c++·算法·leetcode·矩阵·模拟·数组·
Tisfy20 天前
LeetCode 1886.判断矩阵经轮转后是否一致:模拟
算法·leetcode·矩阵·题解·模拟
Tisfy21 天前
LeetCode 3643.垂直翻转子矩阵:原地修改
算法·leetcode·矩阵·模拟
Tisfy22 天前
LeetCode 3567.子矩阵的最小绝对差:暴力模拟
leetcode·矩阵·题解·模拟·暴力