7-5 求前N天 (30 分)(java-pta作业)

7-5 求前N天 (30 分)

注:仅供参考,抄袭后果自负
输入年月日的值(均为整型数),同时输入一个取值范围在[-10,10] 之间的整型数n,输出该日期的前n天(当n > 0时)、该日期的后n天(当n<0时)。
其中年份取值范围为 [1820,2020] ,月份取值范围为[1,12] ,日期取值范围为[1,31] 。
注意:不允许使用Java中任何与日期有关的类或方法。

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

输出格式:
当输入的年、月、日以及n的值非法时,输出“Wrong Format”;
当输入数据合法时,输出“n days ago is:年-月-日”
输入样例1:
在这里给出一组输入。例如:

2018  6 19 8 

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

8 days ago is:2018-6-11

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

2018  6 19 -8 

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

-8 days ago is:2018-6-27

代码如下


import java.util.Scanner;
public class Main {


	public static void main(String[] args)//主方法
	{
	
		Scanner in = new Scanner(System.in);
		int a,year,month,day;
		
		year = in.nextInt();
		month = in.nextInt();
		day = in.nextInt();
		a = in.nextInt();
		
		if(checkInputValidity ( year, month, day))
		{
			
			
			
			 nextDate( year, month,day, a);
		}
		else
		{
			System.out.println("Wrong Format");
		    System.exit(0);
		}
		
	}
	public static boolean isLeapYear (int year) //判断year是否为闰年,返回boolean类型 
	{
		if(year %400==0||(year%4==0&&year%100!=0))
			return true;
		else 
			return false;
	}


	public static boolean  checkInputValidity (int year,int month,int day)
	{
		
		int[] qz = {0,31,28,31,30,31,30,31,31,30,31,30,31};
		if(year<1820||year>2020)
		    return false;
		else if(month<1||month>12)
		 return false;
		else if(day<1||day>31)
			return false;
		else
		{
			if(month==2&&isLeapYear(year))
			{
				if(day>qz[2]+1)
				{
					return false;
				}
				else
				{
					return true;
				}
			}
			else
			{
				if(day>qz[month])
				{
					return false;
				}
				else
				{
					return true;
				}
			}
		}
	}
	public static void nextDate(int year,int month,int day,int a)
	{
		int[] qz1 = {0,31,28,31,30,31,30,31,31,30,31,30,31};
		int[] qz2= {0,31,29,31,30,31,30,31,31,30,31,30,31};
		if(a>0)
		{
			for(int i=0;i<a;i++)
			{
				
				if(isLeapYear(year))
				{
					if(day==1)
					{
						month--;
						if(month==0)
						{
							year--;
							month=12;
						}
						day=qz2[month];
					}
					else
						day--;
				}
				else
				{
					if(day==1)
					{
						month--;
						if(month==0)
						{
							year--;
							month=12;
						}
						day=qz1[month];
					}
					else
						day--;
				}
			}
		}
		else
		{
			for(int i=-a;i>0;i--)
			{
				if(isLeapYear(year))
				{
					if(day==qz2[month])
					{
						day=1;
						month++;
						if(month==13)
						{
							year++;
							month=1;
						}
						
					}
					else
						day++;
				}
				else
				{
					if(isLeapYear(year))
					{
						if(day==qz2[month])
						{
							day=1;
							month++;
							if(month==13)
							{
								year++;
								month=1;
							}
							
						}
						else
							day++;
					}
                    else
                    {
                        if(day==qz1[month])
						{
							day=1;
							month++;
							if(month==13)
							{
								year++;
								month=1;
							}
							
						}
						else
							day++;
                    }
				}
			}
	
		}
		System.out.println(a + " days ago is:" + year + "-" + month + "-" + day);
	}	
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值