NCHU_求前\后N天

import java.util.Scanner;
public class Main 
{
	static int []days = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
	public static void main(String[] args)
	{
		Scanner sc = new Scanner(System.in);
		int year,month,day;
		int n;
		year=sc.nextInt();
		month=sc.nextInt();
		day=sc.nextInt();
		n=sc.nextInt();
		if(!check(year,month,day)||n<-10||n>10||year<1820||year>2020) 
		{
			System.out.printf("Wrong Format");
			return;
		}
        if(year%400==0||year%100!=0&&year%4==0)//闰年
			days[2]=29;
		if(day-n>0&&(day-n)<=days[month])//本月
		{
			System.out.printf("%d-%d-%d",year,month,day-n);
		}
		if(day-n<=0)//回到上一个月
		{
			if(month-1>0)//本年
			{
				int day2=days[month-1]-Math.abs(day-n);
				System.out.printf("%d-%d-%d",year,month-1,day2);
			}
			else//上一年
			{
				int day2=days[12]-Math.abs(day-n);
				System.out.printf("%d-12-%d",year-1,day2);
			}
			
		}
		if(day-n>days[month])//下一个月,年
		{
			if(month+1>12)//下一年
			{
				int day3=(day-n)-days[month];
				System.out.printf("%d-1-%d",year+1,day3);
			}
			else//本年
			{
				int day3=(day-n)-days[month];
				System.out.printf("%d-%d-%d",year,month+1,day3);
			}
		}
	}
	public static boolean check(int a,int b,int c)
	{
		if(b<=0||b>12) return false;
		if(c<=0||b!=2&&c>days[b]) return false;
		if(b==2)
		{
			if(a%400==0||a%100!=0&&a%4==0)//闰年
			{
				if(c>29) return false;
			}
			else
			{
				if(c>28) return false;
			}
		}
		return true;
	}
}

输入年月日的值(均为整型数),同时输入一个取值范围在[-10,10] 之间的整型数n,输出该日期的前n天(当n > 0时)、该日期的后n天(当n<0时)。
其中年份取值范围为 [1820,2020] ,月份取值范围为[1,12] ,日期取值范围为[1,31] 。
注意:闰年判断、日期合法性校验、求前N天、求后N天均要定义为独立的函数,且函数定义必须符合 SOC(Separation of Concerns)思想和SRP(Single Responsibility Principle)原则。

输入格式:

在一行中输入年月日的值以及n的值,可以用一个或多个空格或回车分隔。

输出格式:

  1. 当输入的年、月、日以及n的值非法时,输出“Wrong Format”;
  2. 当输入数据合法时,输出“年-月-日”

输入样例1:

在这里给出一组输入。例如:

2018  6 19 8 

输出样例1:

在这里给出相应的输出。例如:

2018-6-11

输入样例2:

在这里给出一组输入。例如:

2018  6 19 -8 

输出样例2:

在这里给出相应的输出。例如:

2018-6-27
  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值