算法竞赛---day10(星系炸弹)

我们处理一件事情,遇到困难,当怀疑自己的时候,请试试想想自己曾经做这件事的初衷。。。
17年的真题真心难啊~第一道程序编程即日期问题,真的把我难住了,即便看了答案也懵懵懂懂的,虽然整体不是太难理解,但在编程时的很多知识点都是我的盲区,所以我只能暂时将他放一放,先来练练蓝桥杯其他几个年份的日期类问题,最后再来处理这个老大难问题。
题目描述
在X星系的广袤空间中漂浮着许多X星人造“炸弹”,用来作为宇宙中的路标。每个炸弹都可以设定多少天之后爆炸。比如:阿尔法炸弹2015年1月1日放置,定时为15天,则它在2015年1月16日爆炸。有一个贝塔炸弹,2014年11月9日放置,定时为1000天,请你计算它爆炸的准确日期。请填写该日期,格式为 yyyy-mm-dd 即4位年份2位月份2位日期。比如:2015-02-19。请严格按照格式书写。不能出现其它文字或符号。
分析
这题是15年的第二个填空题,虽然说理解编码什么的都挺简单,但这题很有意思,尤其是几个细节很不错,我拿出来分享一下,从中真的可以体会到编程的乐趣:

  • day[ ]数组之所以给其定义长度13,是为了编码i=1时能够和月份相对应。

  • if(y%400==0||(y%4==0&&y%100!=0)){ day[2]=29; }else{ day[2]=28; }这个闰年判断也很重要!首先位置应该放在for循环下合适,因为y++;会导致年份变化,从而影响二月的天数。其次闰年判断中不仅只对闰年改一下二月的天数,在非闰年的情况下,依旧需要改天数,不然非闰年就也有29天了。

  • day[2]=29;不能写成day[2]++;因为一旦遇见闰年,那么那一年,每增加一天,二月也就会增加一天。

//#include<bits/stdc++.h>
#include<iostream>
using namespace std;
int day[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
int main(){
	int y,m,d,n;
	cin>>y>>m>>d>>n;
	for(int i=1;i<=n;i++){
    	if(y%400==0||(y%4==0&&y%100!=0)){
    		day[2]=29;
    	}else{
    		day[2]=28;
    	}
    	d++;
		if(d==day[m]+1){
			d=1;
			m++;
		}
		if(m==13){
			m=1;
			y++;
		}
	}
	cout<<y<<"-"<<m<<"-"<<d;
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值