Reciprocal cycles

Problem 26

A unit fraction contains 1 in the numerator. The decimal representation of the unit fractions with denominators 2 to 10 are given:
1/20.5
1/30.(3)
1/40.25
1/50.2
1/60.1(6)
1/70.(142857)
1/80.125
1/90.(1)
1/100.1
Where 0.1(6) means 0.166666..., and has a 1-digit recurring cycle. It can be seen that 1/7 has a 6-digit recurring cycle.
Find the value of d < 1000 for which 1/d contains the longest recurring cycle in its decimal fraction part.
def cycle(p, limit):
    if p % 2 == 0 or p % 5 == 0:
        return 0
    n = 1
    while n < limit:
        if pow(10, n, p) == 1:
            return n
        n += 1


def run(limit=1000):
    result = 0
    for n in range(2, limit):
        c = cycle(n, 2 * limit)
        if c > result:
            result, nx = c, n

    return nx