zoukankan      html  css  js  c++  java
  • 蓝桥杯2015初赛星系炸弹

    在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
    输出
    请填写该日期,格式为 yyyy-mm-dd 即4位年份2位月份2位日期。比如:2015-02-19
    请严格按照格式书写。不能出现其它文字或符号。
    样例输入 Copy
    2015 1 1 15
    2014 11 9 1000
    样例输出 Copy
    2015-01-16
    2017-08-05
    提示
    题目已改编。


    思路1.
    先判断是否为闰年,这会影响2月份是28还是29,如果是闰年,2月份是29,如果不是,就是28
    之后将增加的n年,用循环拆成,一天一天的加,同时更新月份和年份。

    #include<iostream>
    using namespace std;
    int f(int x)
    {
    	if(x%4==0&&x%100!=0||x%400==0)
    	{
    		return 1;
    	}else
    	{
    		return 0;
    	}
    }	
    int d[12]={31,28,31,30,31,30,31,31,30,31,30,31};//不是闰年的月份数组。
    int main()
    {
    	int a,b,c,n;
    	while(cin>>a>>b>>c>>n)
    	{
    	
    		for(int i=1;i<=n;i++)
    		{
    			if(f(a))
    			d[1]=29;
    			else
    			d[1]=28;
    			if(++c>d[b-1])
    			{
    				c=1;
    				b++;
    			}
    			if(b>12)
    			{
    				a++;
    				b=1;
    			}
    		}
    		printf("%d-%02d-%02d
    ",a,b,c);//%02d表示占两个位置,如果位置不够,就用0来占。
    	}
    	return 0;
    }
    
  • 相关阅读:
    [leetcode]_Search Insert Position
    [leetcode]_Merge Two Sorted Lists
    [leetcode]_Valid Parentheses
    喧闹中坚守底线-徘徊的行走在不知道路在何方的大地上。
    [leetcode]_Longest Common Prefix
    [leetcode]_Remove Nth Node From End of List
    [leetcode]_Roman to Integer
    [leetcode]_Palindrome Number
    策略模式(Strategy)
    面向对象
  • 原文地址:https://www.cnblogs.com/YenKoc/p/12779966.html
Copyright © 2011-2022 走看看