一、题目
二、算法思想
- 首先需要解决的是年份、月份和日期,可以使用
字符串.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;
}
}