本文主要是介绍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;}elsereturn 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;}elsereturn 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;}
}
这篇关于Java-PTA 那天是周几呢?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!