当前位置: 代码迷 >> J2SE >> 万年历解决方法
  详细解决方案

万年历解决方法

热度:159   发布时间:2016-04-24 02:14:46.0
万年历
Java code
package kaoshi;import java.util.Scanner;public class PrintCalendar {    /**     * @param args     */    public static void main(String[] args) {        System.out.println("******************欢 迎 使 用 万 年 历******************");        Scanner input = new Scanner(System.in);        System.out.print("\n请选择年份: ");        int year = input.nextInt();        System.out.print("\n请选择月份: ");        int month = input.nextInt();        System.out.println();        int days = 0; // 存储当月的天数        boolean isRn;        /* 判断是否是闰年 */        if (year % 4 == 0 && !(year % 100 == 0) || year % 400 == 0) { // 判断是否为闰年            isRn = true; // 闰年        } else {            isRn = false;// 平年        }        /* 计算输入的年份之前的天数 */        int totalDays = 0;        for (int i = 1900; i < year; i++) {            /* 判断闰年或平年,并进行天数累加 */            if (i % 4 == 0 && !(i % 100 == 0) || i % 400 == 0) { // 判断是否为闰年                totalDays = totalDays + 366; // 闰年366天            } else {                totalDays = totalDays + 365; // 平年365天            }        }        /* 计算输入月份之前的天数 */        int beforeDays = 0;        for (int i = 1; i <= month; i++) {            switch (i) {              case 1:              case 3:              case 5:              case 7:              case 8:              case 10:              case 12:                days = 31;                break;              case 2:                if (isRn) {                    days = 29;                } else {                    days = 28;                }                break;              default:                days = 30;                break;            }            if (i < month) {                beforeDays = beforeDays + days;            }        }        totalDays = totalDays + beforeDays; // 距离1900年1月1日的天数        /* 计算星期几 */        int firstDayOfMonth; // 存储当月第一天是星期几:星期日为0,星期一~星期六为1~6        int temp = 1 + totalDays % 7; // 从1900年1月1日推算   (问题1:这里为什么要+1)        if (temp == 7) { // 求当月第一天            firstDayOfMonth = 0; // 周日        } else {            firstDayOfMonth = temp;        }        /* 输出日历 */        System.out.println("星期日\t星期一\t星期二\t星期三\t星期四\t星期五\t星期六");        for (int nullNo = 0; nullNo < firstDayOfMonth; nullNo++) {            System.out.print("\t"); // 输出空格        }        for (int i = 1; i <= days; i++) {            System.out.print(i + "\t");            if ((totalDays + i-1 ) % 7 == 5) { // 如果当天为周六,输出换行(问题2:这里为什么要i-1)                System.out.println();            }        }    }}


------解决方案--------------------
问题一下面不是接着就判断当月第一天是周几么?Mod(n,7)的余数是0……6,下面的判断逻辑是用==7来判断是否是周日的,所以+1。
问题二是输出从当天开始算起至月末的日历。当天总不能+1吧(因为你的计数器是从1开始的),如果你改成for(int i=0;i<days,i++),那你可以不用-1.
  相关解决方案