星系炸弹

星系炸弹

在X星系的广袤空间中漂浮着许多X星人造“炸弹”,用来作为宇宙中的路标。
每个炸弹都可以设定多少天之后爆炸。
比如:阿尔法炸弹2015年1月1日放置,定时为15天,则它在2015年1月16日爆炸。
有一个贝塔炸弹,a年b月c日放置,定时为n天,请你计算它爆炸的准确日期。

输入

输入存在多组数据,每组数据输入一行,每一行输入四个正整数a,b,c,n
输入保证日期在1000-01-01到2020-01-01之间,且日期合法。
n不超过1000

2015 1 1 15
2014 11 9 1000

输出

请填写该日期,格式为 yyyy-mm-dd 即4位年份2位月份2位日期。比如:2015-02-19
请严格按照格式书写。不能出现其它文字或符号。

2015-01-16
2017-08-05

解题

c语言版

#include<stdio.h>
using namespace std;
int main()
{
    int a,b,c,d; //年月日
    int day[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};//注意没有day[0] 随便附个值 
    while(scanf("%d %d %d %d",&a,&b,&c,&d)!=EOF)    //不用eof则while(~scanf("%d %d %d %d",&a,&b,&c,&d))也行 
    {
        if(a%4==0&&a%400!=0||a%100==0)//判断闰年
        {
            day[2]=29;
        }
        else
        {
            day[2]=28;
        }
    for(int i=1;i<=d;i++)
    {
        c++;
        if(c>day[b])//日推月
        {
            c=1;
            b++;
        }
        if(b>12)//月推年
        {
            b=1;
            a++;
        }
        if(a%4==0&&a%400!=0||a%100==0)
        {
            day[2]=29;
        }
        else
        {
            day[2]=28;
        }
    }
    printf("%d",a);  //注意留0的问题 此处分部处理
    if(b<10)
    {printf("-0%d",b);}
    else
    printf("-%d",b);
    if(c<10)
    printf("-0%d",c);
    else
    printf("-%d",c);
    }
    return 0;
}

c++版1

#include <iostream>
using namespace std;
int main()
{
    int a,b,c,d; //年月日
    int day[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};    //与上述大同小异
    while(cin>>a>>b>>c>>d)   //此处不能写!=NULL  会判错的
    {      if(a%4==0&&a%100!=0||a%400==0)
        {
            day[2]=29;
        }
        else
        {
            day[2]=28;
        }
        for(int i=1;i<=d;i++)
    {
        c++;
        if(c>day[b])
        {
            c=1;
            b++;
        }
        if(b>12)
        {
            b=1;
            a++;
        }
         if(a%4==0&&a%100!=0||a%400==0)
        {
            day[2]=29;
        }
        else
        {
            day[2]=28;
        }
    }
    cout<<a<<"-";
    if(b<10)
    cout<<"0"<<b<<"-";
    else
    cout<<b<<"-";
    if(c<10)
    cout<<"0"<<c<<endl;
    else
    cout<<c<<endl;
  }
    return 0;
}

c++版本2

此版本借鉴博客园大佬随笔,思路也差不多所用方法有些出入
link.

#include<iostream>
#include<cstring>
#include<iomanip>
#include<cmath>
#include<algorithm>
#include<vector>
using namespace std;


bool judge(int y)//判断是不是闰年 
{
    if(y%4==0&&y%100!=0||y%400==0)
    return true;
    else
    return false;
}
int mon[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
int main()
{
    int year,month,day;
    int n;
while(    cin>>year>>month>>day>>n)
{

    while(n)
    {
            if(judge(year))
          {
        mon[2]=29;
         }
         else
         mon[2]=28;
        if(day<=mon[month])
        day++;
        if(day>mon[month])
         {
         day=1;
         month++;
        }
        if(month>12)
        {
         year++;
         month=1;
       }
        n--;   
    }
    cout<<year<<"-";
    if(month<10)
    cout<<"0"<<month<<"-";
    else
    cout<<month<<"-";
    if(day<10)
    cout<<"0"<<day<<endl;
    else
    cout<<day<<endl;
  }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值