计算今天是星期几

题目:按照年 月 日的格式输入今天的日期。计算和输出今天是星期几的信息。用y m d代表输入的年 月 日

思路:其实原则是就是把公元0000年到今天的天数加起来除以7得到余数即可,但是这样好像不太现实。换个思路呗,闰年除以7余数是2,平年除以7余数是1,这么一来数的大小变小了塞,然后就是判断0000年到去年的闰年数目,公式是(y-1)/4 - (y-1)/4 +(y-1)/4,再乘以余数的话年份除以7的余数和为:y-1+(y-1)/4 - (y-1)/4 +(y-1)/4。剩下的就是计算今年1月到m-1的月份天数之和,然后加上d,除以7,输出结果,这些都是小case了。

源代码:

import java.util.Scanner;
public class Main4 {
public static void main(String[] args) {
int[] months = {0,31,28,31,30,31,30,31,31,30,31,30,31};
Scanner in = new Scanner(System.in);
int year = in.nextInt();
int month = in.nextInt();
int day = in.nextInt();
if(true == isRunNian(year)){//今年如果是闰年,2月份天数对7的余数加1
months[2]++;
}
int yearMod = year-1+(year-1)/4-(year-1)/100+(year-1)/400;  //y-1年对7的余数
   int monthMod = 0;
   for(int i=1;i    monthMod += months[i];
   }
   int result = (yearMod+monthMod+day)%7;
   String str = "";
   switch(result){
   case 0:
    str = "星期日";
    break;
   case 1:
    str = "星期一";
    break;
   case 2:
    str = "星期二";
    break;
   case 3:
    str = "星期三";
    break;
   case 4:
    str = "星期四";
    break;
   case 5:
    str = "星期五";
    break;
   default:
    str = "星期六";
    break;
   }    
   System.out.println(str);
}

//判断是不是闰年
public static boolean isRunNian(int year){
if((year%4 == 0 && year%100 != 0)|| year%400 == 0){
return true;
}else{
return false;
}
}
}


代码中未对输入的数值有误做出判断处理。欢迎大神指点更好的方法!

你可能感兴趣的:(算法,Java)