Problem B: 星系炸弹

本文介绍了一种算法,用于计算星系中人造炸弹的爆炸日期。通过输入炸弹的初始放置日期和定时天数,算法能够计算出精确的爆炸日期,并以特定格式输出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<pre name="code" class="html">Problem B: 星系炸弹Time Limit:Memory Limit:128 MB
Submit: 12  Solved: 3
Description:在X星系的广袤空间中漂浮着许多X星人造“炸弹”,用来作为宇宙中的路标。每个炸弹都可以设定多少天之后爆炸。比如:阿尔法炸弹2015年1月1日放置,定时为15天,则它在2015年1月16日爆炸。有一个贝塔炸弹,2014年11月9日放置,定时为1000天,请你计算它爆炸的准确日期。


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


#include<iostream>
#include<stdio.h>
using namespace std;
int a[13]={0,31,0,31,30,31,30,31,31,30,31,30,31};
bool runnian(int y)                           //闰年判断
{
	if(y%4==0&&y%100!=0 || y%400==0) return 1;
	else return 0;
}
int main()
{
	int  yyyy,mm,dd;
	int n;
	while(scanf("%d-%d-%d",&yyyy,&mm,&dd)!=EOF)
	{
		cin>>n;
		int i=mm,sum=0;
		while(i)                             //i 控制月份;
		{  
		   dd++;
		   if(runnian(yyyy)) a[2]=29; //是闰年或者不是闰年日期不同
		   else a[2]=28;
		   if(i==12&&dd>31){i=1;yyyy++;mm=1;dd=1;}  // 当月份积累的够的时候 就将月份变为一月,年份加1,日夜变为1
		   if(dd>a[i]){mm++;dd=1;i++;	} //当日满的时候,月份就加一,日变成1。
		   sum++; 
		   
		   if(n==sum)break;   //加够足够的日子就跳出来
		  // cout<<yyyy<<"-"<<mm<<"-"<<dd<<endl;
	    }
	    cout<<yyyy<<"-";               //坑爹的输出格式/。。。。。。。。
	    if(mm<10)cout<<"0"<<mm;
	    else cout<<mm;
	    cout<<"-";
	    if(dd<10) cout<<"0"<<dd<<endl;
	    else cout<<dd<<endl;
	}
	return 0;
}
MD,没有认真读题,,,,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值