其他分享
首页 > 其他分享> > 判断星期几

判断星期几

作者:互联网

今天看见一个很有意思的题目。大致是,已知1970年1月1日为星期四,判断某天是星期几。一开始想简单了,没有把1970到输入的年份中间的算进去。后来改好了。觉得自己的思路还行,就粘出来


    public static void main(String[] args) {
        ZWLT zwlt = new ZWLT();
        // 星期五
        System.out.println(zwlt.t2(1970, 1, 2));
        // 星期六
        System.out.println(zwlt.t2(2022, 1, 1));
        // 星期四
        System.out.println(zwlt.t2(2022, 1, 6));
    }
    /**
     * 已知1970年1月1日为星期四,判断某天是星期几
     * @param year
     * @param month
     * @param day
     * @return
     */
    public int t2(int year, int month, int day) {
        int res = 4;
        for (int i = 1970; i < year; i++) {
            res += (getYear(i)) % 7;
        }
        res += (geyMonth(year, month - 1) + getDay(day)) % 7;
        return (res) % 7;
    }
    private int getDay(int day) {
        return day % 7;
    }
    // 按照偏移来累加
    private int geyMonth(int year, int month) {
        int monthD = 0;
        switch (month) {
            case 11: monthD += 30;
            case 10: monthD += 31;
            case 9: monthD += 30;
            case 8: monthD += 31;
            case 7: monthD += 31;
            case 6: monthD += 30;
            case 5: monthD += 31;
            case 4: monthD += 30;
            case 3: monthD += 31;
            case 2: monthD += 29;
            case 1: monthD += 31;
            case 0: monthD += 0;
        }
        if(!isLeapYear(year)) {
            monthD --;
        }
        return monthD % 7;
    }
    private int getYear(int year) {
        if(isLeapYear(year)) {
            return 366 % 7;
        } else {
            return 365 % 7;
        }
    }
    private boolean isLeapYear(int year) {
        if (year % 4 == 0 && year % 100 != 0) {
            return true;
        } else if (year % 400 == 0) {
            return true;
        } else {
            return false;
        }
    }

标签:星期,case,判断,return,int,31,year,monthD
来源: https://blog.csdn.net/zhuiQiuMX/article/details/122350503