7-3 判断闰年及星期几 (20 分)(java-pta作业)

7-3 判断闰年及星期几 (20 分)

注:仅供参考和交流,抄袭后果自负

输入年月日的值(均为整型数),输出该年份是否为闰年,同时输出该日期为星期几。 其中:年份的合法取值范围为[1820,2020] ,月份合法取值范围为[1,12] ,日期合法取值范围为[1,31] ; 判断星期几的算法如下:假定公元0001年1月1日为星期一,因此只要计算出当前输入日期离0001年1月1日所差的天数,然后拿这个天数除以7求余数,当余数为0时,为星期日,当余数为1时,为星期一,以此类推,当余数为6时,为星期六。

要求:Main类中必须含有如下方法,签名如下:

public static void main(String[] args);//主方法;
public static boolean isLeapYear(int year) ;//判断year是否为闰年,返回boolean类型;
public static int numOfDays(int year,int month ,int day) ;//求出year-month-day到0001-1-1的距离天数,返回整型数;
public static String getWhatDay(int days) ; //根据天数返回星期几,其中参数days为天数,整型数,返回星期几的英文单词。
注意:不允许使用Java中和日期相关的类和方法。

输入格式:
在一行内输入年月日的值,均为整型数,可以用一到多个空格或回车分隔。

输出格式:
当输入数据非法及输入日期不存在时,输出“Wrong Format”;
当输入日期合法,以如下格式输出两行数据(注意,两行末尾均有个.)
第一行:年份(值) is a leap year.
第二行:年-月-日(均为变量值) is 星期几(输出为星期日到星期六的英文单词).
输入样例1:
在这里给出一组输入。例如:

2020 3 9

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

2020 is a leap year.
2020-3-9 is Monday.

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

1835 12 31

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

1835 is not a leap year.
1835-12-31 is Thursday.

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

1999 9 31

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

Wrong Format

import java.util.Scanner;
public class Main {

	public static void main(String[] args)
	{
		Scanner in = new Scanner(System.in);
		int year,day,month;
		int days;

		year = in.nextInt();
		month = in.nextInt();
		day = in.nextInt();
		if(checkInputValidity(year,month,day))
        {
                 days=numOfDays(year,month ,day);
					String s=getWhatDay(days);
                if(isLeapYear(year))
                    System.out.println(year +" is a leap year.");
                else
                    System.out.println(year +" is not a leap year.");
            
				System.out.println(year+ "-" + month + "-" + day+" is " +s +"." );
        }
        else
        {
            System.out.println("Wrong Format");
				    System.exit(0);
        }

		}
		

		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 boolean isLeapYear(int year)
	{
		
		if(year % 400==0||(year%4==0&&year%100!=0))
			return true;
		else
			return false;
	}
	public static int numOfDays(int year,int month ,int day)
	{
		int days=0,i;
		int[] yy = {0,31,28,31,30,31,30,31,31,30,31,30,31};
		for(i=1;i<year;i++)
		{
			if(isLeapYear(i))
			{
				days=days+2;
			}
			else
				days=days+1;

		}
		if(isLeapYear(year))
		{
            days=days+day;
			yy[2]++;
			for(i=1;i<month;i++)
				days=days+yy[i];
		}
		else
		{
            days=days+day;
			for(i=1;i<month;i++)
				days=days+yy[i];
		}
		
		return days;
	}
	public static String getWhatDay(long days)
	{
		long a;
		a=days%7;
       	if(a==0)
			return "Sunday";
		else if(a==1)
			return "Monday";
		else if(a==2)
			return "Tuesday";
		else if(a==3)
			return "Wednesday";
		else if(a==4)
			return "Thursday";
		else if(a==5)
			return "Friday";
		else 
			return "Saturday";
	}
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值