Java-PTA 那天是周几呢?

一、题目

在这里插入图片描述
在这里插入图片描述

二、算法思想

  • 首先需要解决的是年份、月份和日期,可以使用字符串.split('分隔符')的方法,将一个字符串以-为标志,切分成三个部分
  • 由于split方法是返回的String[]类型,所以需要定义一个字符串数组来存储分割后的年、月、日
  • 然后再通过Integer.parseInt(字符串)将年、月、日转换为整型
Scanner scanner = new Scanner(System.in);
String now = scanner.next();//输入
//年月日处理
String[] str = now.split("-");
int year = Integer.parseInt(str[0]);//年份
int month = Integer.parseInt(str[1]);//月份
int day = Integer.parseInt(str[2]);//日
  • 由于闰年和平年的情况是不同的,所以需要设计一个方法isRun来判断当前的年份是否为闰年。
  • 闰年分为普通闰年和世纪闰年,普通闰年为4的倍数但不为100的倍数,而世纪闰年为100的倍数同时也是400的倍数。
public static boolean isRun(int year){//判断该年是否为闰年
        if(year%4==0&&year%100!=0){//是否为普通闰年
            return true;
        }
        else if(year%100==0&&year%400==0){//是否为世纪闰年
            return true;
        }
        return false;
}
  • 题目提到需要输出两个答案,一个是周几、一个是天数
    我们可以先去考虑天数的计算,之后周几可以通过天数来求。
  • 先定以一个整型数组,存储的是平年情况下各个月份的天数
    然后再通过之前设计的isRun方法判断是否为闰年
  • 如果为闰年时就将2月天数设为29
  • 之后就是遍历这个整型数组months,另外用一个变量number累加计算对应的月份天数,与当前的月份相同时退出循环
  • 最后加上日期就是结果了
public static int find_day(int year,int month,int day){//天数
        int []months = {31,28,31,30,31,30,31,31,30,31,30,31};//为平年情况下,每个月份对应的天数
        int number = 0;//需要输出的天数
        if(isRun(year)) {//为闰年时
            months[1] = 29;//闰月
        }
        for(int i=0;i<months.length;i++){//编辑months数组
            if(i + 1 == month){//与月份相同时
                break;
            }else{
                number += months[i];
            }
        }
        number += day;//添加当前月份多出来的日期
        return number;
}
  • 剩下的一个问题就是求周几,题目没有给一个参考的日期,
    大多情况下,可以用1900年1月1日周一为参考日期,
    或者你自己选择一个已确定周几的日期作为参考日期。
  • 然后计算1900年1月1日距该日期有多少天数
  • 先计算1900年year年之前有的天数,之后加上year年已有的天数就是两者相差的天数。
  • 每周是7天,就将两者的差值对7求余就是周几了,如果为0的时候表示的是周日。
public static int  find_week(int year,int month,int day){//周几
        int number = 0;;//距离1970年1月1日的天数
        for(int i=1900;i<year;i++){
            if(isRun(i)){//闰年
                number += 366;
                //System.out.println("闰: "+i);
            }else{//平年
                number += 365;
                //System.out.println("平: "+i);
            }
        }
        number += find_day(year,month,day);//加上此年的天数
        if(number%7==0){//若余数为0时,表示周日
            return 7;
        }else
            return number%7;
}

三、代码

在这里插入图片描述

import java.util.Scanner;

/*小狐狸FM*/
public class Main{
    public static void main(String[] args) throws Exception{
        Scanner scanner = new Scanner(System.in);
        String now = scanner.next();//输入
        //年月日处理
        String[] str = now.split("-");
        int year = Integer.parseInt(str[0]);//年份
        int month = Integer.parseInt(str[1]);//月份
        int day = Integer.parseInt(str[2]);//日
        //System.out.println(year + " " + month + " " + day);
        //输出
        System.out.println(find_week(year,month,day));//周几
        System.out.println(find_day(year,month,day));//天数
    }
    public static boolean isRun(int year){//判断该年是否为闰年
        if(year%4==0&&year%100!=0){//是否为普通闰年
            return true;
        }
        else if(year%100==0&&year%400==0){//是否为世纪闰年
            return true;
        }
        return false;
    }
    public static int  find_week(int year,int month,int day){//周几
        int number = 0;;//距离1970年1月1日的天数
        for(int i=1900;i<year;i++){
            if(isRun(i)){//闰年
                number += 366;
                //System.out.println("闰: "+i);
            }else{//平年
                number += 365;
                //System.out.println("平: "+i);
            }
        }
        number += find_day(year,month,day);//加上此年的天数
        if(number%7==0){//若余数为0时,表示周日
            return 7;
        }else
            return number%7;
    }
    public static int find_day(int year,int month,int day){//天数
        int []months = {31,28,31,30,31,30,31,31,30,31,30,31};//为平年情况下,每个月份对应的天数
        int number = 0;//需要输出的天数
        if(isRun(year)) {//为闰年时
            months[1] = 29;//闰月
        }
        for(int i=0;i<months.length;i++){//编辑months数组
            if(i + 1 == month){//与月份相同时
                break;
            }else{
                number += months[i];
            }
        }
        number += day;//添加当前月份多出来的日期
        return number;
    }
}
  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦之海岛

创作不易,狐狸叹气

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值