华为2018实习生笔试编程题 二

同 黑色星期五

import java.util.Scanner;

/**
 * 13号又是一个星期五。13号在星期五比在其他日子少吗?计算每个月的十三号落在周一到周日的次数。
 * 给出N年的一个周期,要求计算1900年1月1日至1900+N-1年12月31日中十三号落在周一到周日的次数,N为正整数且不大于400.
 */

public class test04 {

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        //int weeks = sc.nextInt();//用來求13号是星期weeks的天数
        int[] a = new int[7];//0-6表示星期日到星期六
        int week = 6;//1990年1月1号星期一,13号星期六
        for (int i = 1900; i < 1900 + n; i++) {
            for (int j = 1; j <= 12; j++) {
                a[week % 7]++;
                week += get(i, j);
            }
        }
        for (int i = 1; i <= 6; i++) {
            System.out.print(a[i] + " ");//星期一到星期六
        }
        System.out.print(a[0] + " ");//13号等于星期天的天数
        //System.out.println(a[weeks]);
    }
    public static int get(int y, int m) {
        int i;
        if ((y % 4 == 0 && y % 100 != 0) || (y % 400 == 0))
            i = 1;
        else
            i = 0;
        if (m == 1 || m == 3 || m == 5 || m == 7 || m == 8 || m == 10 || m == 12)
            return 31;
        else if (m == 2) {
            if (i == 1)
                return 29;
            else
                return 28;
        }
        return 30;
    }
}


猜你喜欢

转载自blog.csdn.net/ncut_nwpu/article/details/79996019