aboutsummaryrefslogtreecommitdiff
path: root/challenge-138/abigail/java/ch-1.java
blob: 41378a448ca8db3cb7109edf952a798b137d207d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
//
// See ../README.md
//

//
// Run as: ln ch-1.java ch1.java; javac ch1.java; java ch1 < input-file
//

import java.util.*;

public class ch1 {
    static int [] [] lookup = {
        {261, 260, 260, 261, 261, 261, 261},
        {262, 261, 260, 261, 262, 262, 262},
    };

    public static final int SUNDAY    = 0;
    public static final int MONDAY    = 1;
    public static final int TUESDAY   = 2;
    public static final int WEDNESDAY = 3;
    public static final int THURSDAY  = 4;
    public static final int FRIDAY    = 5;
    public static final int SATURDAY  = 6;

    static int [] anchors = {TUESDAY, SUNDAY, FRIDAY, WEDNESDAY};

    public static int doomsday (int year) {
        int anchor = anchors [(year / 100) % 4];
        int y      = year % 100;
        return (((y / 12) + (y % 12) + ((y % 12) / 4)) + anchor) % 7;
    }

    public static int is_leap (int year) {
        if ((year % 400 == 0) || (year % 4 == 0) && (year % 100 != 0)) {
            return 1;
        }
        return 0;
    }

    public static void main (String [] args) {
        Scanner scanner = new Scanner (System . in);
        while (scanner . hasNextInt ()) {
            int year = scanner . nextInt ();
            System . out . println (lookup [is_leap (year)] [doomsday (year)]);
        }
    }
}