Smallest Integer Divisible by K

medium math hash map

Problem

Return the length of the smallest positive integer made only of 1s that is divisible by k. If none exists, return -1.

Inputk = 3
Output3
Track remainder r; r = (10r + 1) mod k. r repeats ⇒ no solution (k divisible by 2 or 5).

def smallestRepunitDivByK(k):
    if k % 2 == 0 or k % 5 == 0: return -1
    r, length = 0, 0
    for _ in range(k):
        r = (r * 10 + 1) % k
        length += 1
        if r == 0: return length
    return -1
function smallestRepunitDivByK(k) {
  if (k % 2 === 0 || k % 5 === 0) return -1;
  let r = 0, length = 0;
  for (let i = 0; i < k; i++) {
    r = (r * 10 + 1) % k;
    length++;
    if (r === 0) return length;
  }
  return -1;
}
class Solution {
    public int smallestRepunitDivByK(int k) {
        if (k % 2 == 0 || k % 5 == 0) return -1;
        int r = 0, length = 0;
        for (int i = 0; i < k; i++) {
            r = (r * 10 + 1) % k;
            length++;
            if (r == 0) return length;
        }
        return -1;
    }
}
int smallestRepunitDivByK(int k) {
    if (k % 2 == 0 || k % 5 == 0) return -1;
    int r = 0, length = 0;
    for (int i = 0; i < k; i++) {
        r = (r * 10 + 1) % k;
        length++;
        if (r == 0) return length;
    }
    return -1;
}
Time: O(k) Space: O(1)