头像

Cyan

四川成都

深度强化学习炼丹师

2015年第六届蓝桥杯省赛-B. 星系炸弹

2015年第六届蓝桥杯省赛-B. 星系炸弹

2021-12-16 · 110次阅读 · 原创 · 数据结构与算法

原题链接

题面

在 X 星系的广袤空间中漂浮着许多X星人造“炸弹”,用来作为宇宙中的路标。 每个炸弹都可以设定多少天之后爆炸。

比如:阿尔法炸弹2015年1月1日放置,定时为15天,则它在2015年1月16日爆炸。

有一个贝塔炸弹,2014年11月9日放置,定时为1000天,请你计算它爆炸的准确日期。

请输出该日期,格式为 yyyy-mm-dd 即 4 位年份 2 位月份 2 位日期。比如:2015-02-19。

题解

日期计算,枚举

常规签到题,具体见代码。亦可以使用计算器和Excel函数。

答案:

2017-08-05

代码

#include<iostream> using namespace std; int mon[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; struct Date { int year, month, day; }; bool leap_year(int y) { return (y % 4 == 0 && y % 100 != 0) || y % 400 == 0; } //求从date开始为第一天,到第 dd 天的日期为多少 Date addDays(Date date, int dd) { int cnt = 0; //当年剩余的天数为多少天 for (int m = date.month; m <= 12; m++) { int days = mon[m]; if (m == 2 && leap_year(date.year)) days++; for (int d = (m == date.month ? date.day : 1); d <= days; d++) { if (++cnt == dd) return {date.year, m, d}; } } //当年过后遍历每年每月每天直到天数等于目标天数 for (int y = date.year + 1;; y++) { for (int m = 1; m <= 12; m++) { int days = mon[m]; if (m == 2 && leap_year(y)) days++; for (int d = 1; d <= days; d++) { if (++cnt == dd) return {y, m, d}; } } } return {0, 0, 0}; } int main() { int sy = 2014, sm = 11, sd = 9; int dd = 1000; Date date = addDays({sy, sm, sd}, ++dd); printf("%d-%02d-%02d\n", date.year, date.month, date.day); return 0; }

标题: 2015年第六届蓝桥杯省赛-B. 星系炸弹
链接: https://www.fightingok.cn/detail/173
更新: 2022-09-18 22:45:18
版权: 本文采用 CC BY-NC-SA 3.0 CN 协议进行许可