diff options
| author | drbaggy <js5@sanger.ac.uk> | 2022-06-07 13:50:49 +0100 |
|---|---|---|
| committer | drbaggy <js5@sanger.ac.uk> | 2022-06-07 13:50:49 +0100 |
| commit | 26c48d1d97f7882cfd69edea26b78cf7a5095b69 (patch) | |
| tree | b761863c543dac609a7404b524d7cc997d19de6d /challenge-168/roger-bell-west/python/ch-2.py | |
| parent | 8788ff5949846c60508766c5c407fde159e832d3 (diff) | |
| parent | 031fbe8a0c7289a18eb966600fe424891d7875e1 (diff) | |
| download | perlweeklychallenge-club-26c48d1d97f7882cfd69edea26b78cf7a5095b69.tar.gz perlweeklychallenge-club-26c48d1d97f7882cfd69edea26b78cf7a5095b69.tar.bz2 perlweeklychallenge-club-26c48d1d97f7882cfd69edea26b78cf7a5095b69.zip | |
Merge remote-tracking branch 'upstream/master'
Diffstat (limited to 'challenge-168/roger-bell-west/python/ch-2.py')
| -rwxr-xr-x | challenge-168/roger-bell-west/python/ch-2.py | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/challenge-168/roger-bell-west/python/ch-2.py b/challenge-168/roger-bell-west/python/ch-2.py new file mode 100755 index 0000000000..3811fded6f --- /dev/null +++ b/challenge-168/roger-bell-west/python/ch-2.py @@ -0,0 +1,76 @@ +#! /usr/bin/python3 + +import unittest + +from math import sqrt,floor,gcd +from collections import deque + +def genprimes(mx): + primesh=set(range(2,4)) + for i in range(6,mx+2,6): + for j in range(i-1,i+2,2): + if j <= mx: + primesh.add(j) + q=deque([2,3,5,7]) + p=q.popleft() + mr=floor(sqrt(mx)) + while p <= mr: + if p in primesh: + for i in range(p*p,mx+1,p): + primesh.discard(i) + if len(q) < 2: + q.append(q[-1]+4) + q.append(q[-1]+2) + p=q.popleft() + primes=list(primesh) + primes.sort() + return primes + +def primefactor(n): + f=dict() + m=n + for p in genprimes(floor(sqrt(n))): + while (m % p == 0): + m //= p + if p in f: + f[p] += 1 + else: + f[p] = 1 + if m==1: + break + if m > 1: + if m in f: + f[m] += 1 + else: + f[m] = 1 + return f + +def homeprime(n0): + n = n0 + while True: + t = primefactor(n) + tk = list(t.keys()) + tk.sort() + if len(tk) == 1 and t[tk[0]] == 1: + break + ns = "" + for d in tk: + ds = str(d) + for i in range(t[d]): + ns += ds + n = int(ns) + return n + +class TestHomeprime(unittest.TestCase): + + def test_ex1(self): + self.assertEqual(homeprime(10), + 773, + 'example 1') + + def test_ex2(self): + self.assertEqual(homeprime(16), + 31636373, + 'example 2') + +unittest.main() |
