【牛客网题目详解】Q-前天是哪一天
链接: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 <stdio.h>//获取指定月的天数
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 <stdio.h>
#include <time.h>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;
}
【牛客网题目详解】Q-前天是哪一天相关推荐
- 链接:https://ac.nowcoder.com/acm/problem/22228来源:牛客网题目描述 在给定的数组中删除一个数。输入描述:多组测试。每组第一行输入1个整数n(n
链接:登录-专业IT笔试面试备考平台_牛客网 来源:牛客网 题目描述 在给定的数组中删除一个数. 输入描述: 多组测试. 每组第一行输入1个整数n(n<20), 第二行输入n个整数 第三行输入1 ...
- 牛客网题目——不用四则运算符号,计算两个数字的和
牛客网题目--不用四则运算符号,计算两个数字的和 这道题的关键在于理解二进制如何执行两个数的加和操作. 二进制每位相加就相当于各位做异或操作:因此解法大致可以分为两步: 第一步:相加各位的值(下一步再 ...
- 牛客网题目——替换空格
牛客网题目--替换空格 题目描述 请实现一个函数,将一个字符串中的每个空格替换成"%20".例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20 ...
- 牛客网获取输入rowinput_Python爬虫入门例题:抓取牛客网题目
最近做题的时候要写一些题解,在把牛客网的题目复制下来的时候,数学公式的处理比较麻烦,所以我用Python的selenium.urllib.request和BeautifulSoup4库对题目信息进行了 ...
- 使用Python网络爬虫抓取牛客网题目
文章目录 1. 背景 2. 前期准备 3. 获取网页内容 4. 内容处理 4.1. Limit 4.2. Problem Description 4.3. Input 4.4. Output 4.5. ...
- 用Java解决牛客网题目NC510牛妹的礼物
题目描述 众所周知,牛妹有很多很多粉丝,粉丝送了很多很多礼物给牛妹,牛妹的礼物摆满了地板. 地板是N\times MN×M的格子,每个格子有且只有一个礼物,牛妹已知每个礼物的体积. 地板的坐标是左上角 ...
- 用Java解决牛客网题目BC30kiki和酸奶
题目描述 BoBo买了一箱酸奶,里面有n盒未打开的酸奶,KiKi喜欢喝酸奶,第一时间发现了酸奶.KiKi每h分钟能喝光一盒酸奶,并且KiKi在喝光一盒酸奶之前不会喝另一个,那么经过m分钟后还有多少盒未 ...
- 用Java解决牛客网题目WY4炮台攻击
题目描述 兰博教训提莫之后,然后和提莫讨论起约德尔人,谈起约德尔人,自然少不了一个人,那 就是黑默丁格------约德尔人历史上最伟大的科学家. 提莫说,黑默丁格最近在思考一个问题:黑默丁格有三个炮台 ...
- C语言解题——指针解析(牛客网题目)
指针,是C语言中的一个重要概念及其特点,也是掌握C语言比较困难的部分.指针也就是内存地址,指针变量是用来存放内存地址的变量,在同一CPU构架下,不同类型的指针变量所占用的存储单元长度是相同的,而存放数 ...
最新文章
- java类的注释模板_IDEA添加Java类注释模版的方法
- 网线的制作方法和千兆网线的施工注意事项
- python批量读取tiff文件_Python图像分析:从共焦显微镜读取多维TIFF文件
- canvas绘制经典折线图(一)
- 基于java的OA报名与审核管理系统的设计与实现(含源文件)
- 信号signal()、alarm()、信号集函数、sigprocmask()
- matlab函数anova,MATLAB进行单因素方差分析-ANOVA
- Sonic-UI自动化用例编写教程与建议
- win10系统镜像下载及在VMware虚拟机上创建虚拟机
- 我用Vue3+TS实现了一个新年倒计时组件,适用于各种场景
- 小福利,采用excel函数制作大屏可视化,用sumifs函数快速统计汇总数据,锁行锁列以及锁列不锁行
- SVM算法(三层境界)
- 【Android 应用】小白之签名文件的生成。
- 快递行业前景:2022年市场迎来了发展新纪元
- 南京大学考研招生目录、分数线、参考书
- UniAccess Agent 的删除方法
- 关于中标麒麟系统的经历
- 梅科尔工作室-赵一帆-鸿蒙笔记1
- CUDA并行、GLSL并行、CPU并行 相互转换
- SSL协议解析及SSL虚拟专用网