【牛客网题目详解】Q-前天是哪一天
admin
2024-02-17 20:47:50
0

链接:https://ac.nowcoder.com/acm/contest/46295/Q
来源:牛客网

题目描述

给定公元2000年到公元3000年之间的某一天,请你给出该天的前天是哪一天。
(此处略去一张无用的图片)

输入描述

输入在一个日期,格式如"yyyy-mm-dd",题目保证所有输入日期为合法日期。

输出描述

在一行中输出日期,格式如"yyyy-mm-dd"。

示例1

输入

2020-11-15

输出

2020-11-13

备注:

注意日期格式,月份或者天数不足2位要补零。

分析 1

首先考虑输入输出,比较简单

//输入
scanf("%d-%d-%d");//输出
//注意要补零
printf("%04d-%02d-%02d");

算某一天的前天是哪一天很简单,天数 - 2 就可以了。

然后考虑一些特殊情况,比如 9.1 的前一天是 8.30,前一天到上个月去了,月数要减一,天数也要跟着变化。

既然月数要减一,万一是一月怎么办?于是年数也可能要减一,比如 2022.1.1 的前一天就成了 2021.12.30。

天数怎么变呢?很简单,以 9.1 为例

天数为 1
1 - 2 = -1
-1 <= 0 所以月数 - 1,为八月 
八月有 31 天,31 + (-1) = 30
所以前一天是 8.30

可见还得先求出每个月的天数。这就不得不要考虑二月了,于是涉及到了闰年的判断。

参考代码 1

#include //获取指定月的天数
int daysOfMonth(int year, int month)
{switch (month){//大月case 1:  case 3:  case 5:  case 7:  case 8:case 10: case 12:return 31;//二月 需要特殊处理case 2://先判断是否为闰年if (((year % 4 == 0 && year % 100 != 0) || year % 400 == 0))return 29; //闰elsereturn 28; //平//剩下的都是小月default:return 30;}
}int main()
{int year = 0, month = 0, day = 0;scanf("%d-%d-%d", &year, &month, &day);day -= 2;if (day <= 0){month--; //月份的退位if (month <= 0){year--; //年份的退位month = 12;}day += daysOfMonth(year, month);}printf("%04d-%02d-%02d\n", year, month, day);return 0;
}

我到底哪里错了?

请自查以下注意点:

  • 月、年的退位
    • 每月的 1、2 号,每年的 1.1、1.2
  • 大小月的变化
    • 每月的 1、2 号
  • 闰平年的变化
    • 判断是否为闰年的条件有两个
    • 二月的天数很特殊
  • 输出日期的格式
    • 是否补 0

如果实在是找不出来错误在哪里的话,可以用下面的 Python 代码对你的程序进行测试

from datetime import datetime, timedelta
import os
import subprocessprint("开始测试数据")
date = datetime(2000, 1, 1)# 从 2000.1.1 一直枚举到 3000.12.30
while date < datetime(3000, 12, 30):# 获取前天日期testStr = datetime.strftime(date, "%Y-%m-%d") # 转字符串# 运行 C 语言程序p = subprocess.Popen("c.exe", stdin=subprocess.PIPE, stdout=subprocess.PIPE)# C 语言程序输出结果cResult = p.communicate(input=(datetime.strftime(date, "%Y-%m-%d")+"\n").encode("ascii"))[0]cResult = cResult.decode("ascii").replace("\r\n", "")# python 输出结果pyResult = datetime.strftime(date - timedelta(days=2), "%Y-%m-%d")if not (cResult == pyResult):print("错误:" + datetime.strftime(date, "%Y-%m-%d") + " 预期结果 " + pyResult + " 实际结果 " + cResult)exit()else:print("正确:" + datetime.strftime(date, "%Y-%m-%d") + " 预期结果 " + pyResult + " 实际结果 " + cResult)date += timedelta(days=1)

先编译你的 C 语言代码,把编译后的可执行程序重命名为 c.exe,保存以上代码为 whats_the_fxxking_problem_with_my_code.py,把两个文件放在同一文件夹下,然后在该文件夹下启动 Powershell/Cmd,运行 py whats_the_fxxking_problem_with_my_code.py,等待测试完成即可。


* 分析 2

既然 Python 内置时间日期处理库,那么 C 语言有没有?要是有的话直接调不就好了吗?
没错,还真有,只不过没有 Python 的那么方便。

日期时间处理相关的函数都放在 time.h 头文件下。
下面简单做一下相关的笔记:

struct tm //时间日期结构体
time_t //时间戳(自 1970.1.1 00:00:00 以来的秒数)(实际上就是个整数)//将 struct tm(时间日期结构体)转换为 time_t(时间戳)
time_t mktime( struct tm *arg );//将指定 time_t(时间戳)转换为 UTC struct tm(时间日期结构体)
struct tm *gmtime  ( const time_t *timer );//格式化输出struct tm(时间日期结构体)
size_t strftime(char * str,size_t count,const char * format,const struct tm *time );

* 参考代码 2

#include 
#include int main()
{struct tm date = { 0 }; //输入的日期struct tm newDate = { 0 }; //前天的日期time_t newTime = 0;int year = 0, month = 0, day = 0;//C 语言里有时间日期格式化输出,但是好像没有输入,//所以输入还是得手动来//输入日期scanf("%d-%d-%d", &year, &month, &day);//填充结构体数据date.tm_year = year - 1900;date.tm_mon = month - 1;date.tm_mday = day;//tm 结构体转化为 time_t 结构体(时间戳),//再减去两天的秒数,求得前天的时间戳newTime = mktime(&date) - (2 * 24 * 60 * 60);//再将结果转换回 tm 结构体newDate = *gmtime(&newTime);//将 tm 结构体格式化输出char result[64];strftime(result, 64, "%Y-%m-%d", &newDate);printf("%s\n", result);return 0;
}

相关内容

热门资讯

【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...
【已解决】ERROR: Cou... 正确指令: pip install pyyaml
关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
Lock 接口解读 前置知识点Synchronized synchronized 是 Java 中的关键字,...
Win7 专业版安装中文包、汉... 参考资料:http://www.metsky.com/archives/350.htm...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
大模型未来趋势 大模型是人工智能领域的重要发展趋势之一,未来有着广阔的应用前景和发展空间。以下是大模型未来的趋势和展...
python实战应用讲解-【n... 目录 如何在Python中计算残余的平方和 方法1:使用其Base公式 方法2:使用statsmod...
学习u-boot 需要了解的m... 一、常用函数 1. origin 函数 origin 函数的返回值就是变量来源。使用格式如下...
常用python爬虫库介绍与简... 通用 urllib -网络库(stdlib)。 requests -网络库。 grab – 网络库&...
药品批准文号查询|药融云-中国... 药品批文是国家食品药品监督管理局(NMPA)对药品的审评和批准的证明文件...
【2023-03-22】SRS... 【2023-03-22】SRS推流搭配FFmpeg实现目标检测 说明: 外侧测试使用SRS播放器测...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
初级算法-哈希表 主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-哈希表...
进程间通信【Linux】 1. 进程间通信 1.1 什么是进程间通信 在 Linux 系统中,进程间通信...
【Docker】P3 Dock... Docker数据卷、宿主机与挂载数据卷的概念及作用挂载宿主机配置数据卷挂载操作示例一个容器挂载多个目...