aboutsummaryrefslogtreecommitdiff
path: root/challenge-141/abigail/java/ch-2.java
blob: bb03482e678e86469e03052a687167e731008708 (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
//
// See ../README.md
//

//
// Run as: ln ch-2.java ch2.java; javac ch2.java; java ch2 < input-file
//

import java.util.*;

public class ch2 {
    public static int substrings (String n, int m, int prefix, int max) {
        if (n . length () == 0) {
            return prefix > -1   &&
                   prefix < max  &&
                   prefix % m == 0 ? 1 : 0;
        }

        int fc       = Integer . parseInt (n . substring (0, 1));
        int n_prefix = 10 * (prefix == -1 ? 0 : prefix) + fc;
        String tail  = n . substring (1, n. length ());

        return substrings (tail, m, n_prefix, max) +
               substrings (tail, m,   prefix, max);
    }


    public static void main (String [] args) {
        Scanner scanner = new Scanner (System . in);
        while (scanner . hasNextInt ()) {
            int n = scanner . nextInt ();
            int m = scanner . nextInt ();
            System . out . println (
                substrings (Integer . toString (n), m, -1, n));
        }
    }
}