C++类相关oj题目分享(计算日期到天数转换、日期差值、打印日期、日期累加)

文章目录
  • 1.计算日期到天数转换
    • 题目详情
    • 代码
    • 思路
  • 2.KY111 日期差值
    • 题目详情
    • 代码
    • 思路
  • 3.KY222 打印日期
    • 题目详情
    • 代码
  • 4.KY258 日期累加
    • 题目详情
    • 代码
    • 思路

1.计算日期到天数转换

传送门

题目详情

在这里插入图片描述

代码

代码语言:javascript
复制
#include <iostream>
using namespace std;
int GetDay(int year,int month)
{
    int DayOfMonth[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
    if(month==2&&(year%400==0||(year % 4 == 0 && year % 100 )) )
    {
        return 29;
    }
    return DayOfMonth[month];
}

int main() {
int year;
int month;
int day;
cin>>year>>month>>day;
int sum=0;
for(int i=1;i<month;i++)
{
sum+=GetDay(year, i);
}
cout<<sum+day;
}

思路

首先我们知道肯定是用一个数组来储存每个月的天数,更加方便。同时默认2月是28天,如果是闰年就是29。
总体的计算思路是:1月到month-1月的所有天数,加上month月的day。使用for循环能正好契合这个思路
当然这题的思路和解法非常多,我这也只是其中一个。

2.KY111 日期差值

传送门

题目详情

在这里插入图片描述

代码

代码语言:javascript
复制
int GetDay(int year, int month) {//返回一年中哪一个月的天数
    int DayOfMonth[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
    if (month == 2 && (year % 400 == 0 || (year % 4 == 0 && year % 100 )) ) {
        return 29;
    }
    return DayOfMonth[month];
}

int Sum(int a, int b) {
int max = b;
int min = a;
int flag = 1;
if (a > b) {
flag = -1;
max = a;
min = b;
}
int day1 = min % 100;
int month1 = (min / 100) % 100;
int year1 = min / 10000;
int day2 = max % 100;
int month2 = (max / 100) % 100;
int year2 = max / 10000;

int count = 1;
while ((year1 &lt; year2) || (month1 &lt; month2) || (day1 &lt; day2)) {
    day1++;
    if (day1 &gt; GetDay(year1, month1)) { //如果满了当月天数
        month1++;//跳到下一个月,天数变为1号
        day1 = 1;
    }
    if (month1 == 13) { //如果满了当年月数
        year1++;//跳到下一年,月数变为1月
        month1 = 1;
    }
    count++;
}
return flag * count;

}

int main() {
int a, b;
while (cin >> a >> b) {
cout << Sum(a, b) << endl;
}
return 0;
}
}

思路

  1. 首先我们要处理连续输入,之前是使用while(scanf(…)!=EOF)
  • 现在也可以,但毕竟是c++。可以用while(cin<<…)
    因为:例如上面,当使用 while(cin >> a >> b) 时,如果输入操作成功(即用户输入了两个整数),cin 的布尔值为 true,循环会继续执行。如果输入操作失败(例如遇到文件结束符。在 Windows 中是 Ctrl+Z,Linux/macOS 中是 Ctrl+D。这样程序会结束循环并终止执行),cin 的布尔值为 false,循环会终止
  1. 思路是找到二者中较小的,再进行拆分。根据只要二者不相等,day1(较小的)就++;天数满了,月满了再进行处理。每一次count++。

3.KY222 打印日期

传送门

题目详情

在这里插入图片描述

代码

代码语言:javascript
复制
#include <iostream>
using namespace std;

int main() {
int year, sum_day;
while (cin >> year >> sum_day) {
// 注意 while 处理多个 case
int DayOfMonth[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
if (year % 400 == 0 || (year % 4 == 0 && year % 100 ))
{
DayOfMonth[2]++;
}
int month=1;
while(sum_day>DayOfMonth[month])
{
sum_day-=DayOfMonth[month];
++month;
if(sum_day==DayOfMonth[month])
{
++month;
sum_day=1;
break;
}
}
printf("%d-%02d-%02d",year,month,sum_day);
}
}

4.KY258 日期累加

传送门

题目详情

在这里插入图片描述

代码

代码语言:javascript
复制
#include <cfloat>
#include <iostream>
using namespace std;
int GetDay(int year, int month) //返回一年中哪一个月的天数
{
int DayOfMonth[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
if (month == 2 && (year % 400 == 0 || (year % 4 == 0 && year % 100 )) )
{
return 29;
}
return DayOfMonth[month];
}
int main()
{
int num;
cin>>num;
while (num--)
{
int year, month, day,add_day;
cin >> year >> month >> day>>add_day;
while(add_day--)
{
++day;
if (day > GetDay(year, month))
{
++month;
day=1;
}
if(month==13)
{
year++;
month=1;
}
}
printf("%d-%02d-%02d\n",year,month,day);
}
return 0;
}

思路

这题大家要注意题目的输入和输出要求,我自己在这上面浪费了好多多少。


今天就到这里啦!