aboutsummaryrefslogtreecommitdiff
path: root/challenge-136/abigail/java/ch-1.java
blob: 639ef643ca7a2272a0e3a0bdac7c363acb6339d4 (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
48
49
50
51
52
53
54
55
56
57
58
59
60
//
// See ../README.md
//

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

import java.util.*;

public class ch1 {
    //
    // Find the GCD, using Stein's algorithm
    //    (https://en.wikipedia.org/wiki/Binary_GCD_algorithm)
    //
    public static int gcd (int u, int v) {
        boolean u_odd = u % 2 != 0;
        boolean v_odd = v % 2 != 0;

        return u == v || v == 0 ? u
             :           u == 0 ? v
             : !u_odd && !v_odd ? gcd (u >> 1, v >> 1) << 1
             : !u_odd &&  v_odd ? gcd (u >> 1, v)
             :  u_odd && !v_odd ? gcd (u,      v >> 1)
             :  u     >   v     ? gcd (u - v, v)
             :                    gcd (v - u, u);
    }

    //
    // Return true if number is a power of n, that is, number == n ^ p
    // for some non-negative integer p. Return false otherwise.
    //
    public static boolean is_power_of_n (int number, int n) {
        return number <  1     ? false
             : number == 1     ? true
             : number % n != 0 ? false
             : is_power_of_n (number / n, n);
    }

    public static boolean is_power_of_2 (int number) {
        return is_power_of_n (number, 2);
    }

    public static void main (String [] args) {
        Scanner scanner = new Scanner (System . in);
        while (scanner . hasNextInt ()) {
            int n = scanner . nextInt ();
            int m = scanner . nextInt ();
            
            if (n % 2 == 1 || m % 2 == 1) {
                System . out . println ("0");
                continue;
            }

            int r = gcd (n, m);

            System . out . println (r > 1 && is_power_of_2 (r) ? 1 : 0);
        }
    }
}