题目描述:
解题思路:
这是一个变相的日期计算器。只不过2、3、5、7、11月算1天,其他7个月算2天。
既然是一个变相的日期计算器,那就写一个日期计算器,然后加以修改即可。那么,日期计算器怎么写呢?
日期计算器的话,我们将会把日期计算分为三个部分:
第一个不足一年的年份,最后一个不足一年的年份,和中间的足年年份。
足年年份我们只需要判断闰年后加365或366就行了。不足年,我们就要求出这个日期是这一年的第
几天。假设要求的是1994年5月27日到2003年4月29日,那么,我们就要先求出5月27日是这一年的第几天,然后判断1994年不是闰年,不是,所以用365减去这个天数,就得到结果了。本题中第一天也要算,所以还要加上这一天。然后再算出4月29日是2003年的第几天,就可以解决问题了。
所以,我们需要一个函数,功能是给出一个年月日,求出这是这一年的第几天。
这些功能全部实现后,再去改造使得1、4、6、8、9、10、12月的天数翻倍,那么程序就全部完成了。
具体解题思路依据代码并加以画图分析即可理解:
package homeWork;
import java.util.Scanner;
public class work13 {
public static void main(String[] args) {
Scanner scanner=new Scanner(System.in);
while (scanner.hasNext()){
int year1=scanner.nextInt();
int month1=scanner.nextInt();
int day1=scanner.nextInt();
int year2=scanner.nextInt();
int month2=scanner.nextInt();
int day2=scanner.nextInt();
int profit=profitAllYear(year1)-profitOfYear(year1,month1,day1-1);
profit+=profitOfYear(year2,month2,day2);
if (year1==year2){
profit-=profitAllYear(year1);
}
for (int i = year1+1; i <year2 ; i++) {
profit+=profitAllYear(i);
}
System.out.println(profit);
}
}
private static boolean isRun(int year){
if (year%400==0 || ( year%4==0 && year%100!=0 )){
return true;
}
return false;
}
private static boolean isPrime(int month){
if (month==2 || month==3 ||month==5||month==7||month==11){
return true;
}
return false;
}
private static int profitAllYear(int year){
int sum=0;
sum= 2*31+28+31+2*30+31+2*30+31+2*31+2*30+2*31+30+2*31;
if (isRun(year)){
return sum+1;
}else {
return sum;
}
}
private static int profitOfYear(int year,int month,int day){
int profit=0;
if (isPrime(month)){
profit+=day;
}else {
profit+=2*day;
}
while (--month>0){
switch (month){
case 1: case 8: case 10: case 12:profit+=62;
break;
case 3: case 5: case 7:profit+=31;
break;
case 4: case 6: case 9:profit+=60;
break;
case 11:profit+=30;
break;
default:
profit+=(28+(isRun(year)?1:0));
break;
}
}
return profit;
}
}
测试用例均可通过:
- over~✨