aboutsummaryrefslogtreecommitdiff
path: root/challenge-168/roger-bell-west/python/ch-1.py
diff options
context:
space:
mode:
authorRoger Bell_West <roger@firedrake.org>2022-06-06 09:36:01 +0100
committerRoger Bell_West <roger@firedrake.org>2022-06-06 09:36:01 +0100
commit7a504ce6afeb14aa86c830260f0693262a20f9df (patch)
tree82e2c35495e975082aff9ab90b6fd373ec50d1b5 /challenge-168/roger-bell-west/python/ch-1.py
parent34bcab0c854011b9443394ce8b421c7f7f75b161 (diff)
downloadperlweeklychallenge-club-7a504ce6afeb14aa86c830260f0693262a20f9df.tar.gz
perlweeklychallenge-club-7a504ce6afeb14aa86c830260f0693262a20f9df.tar.bz2
perlweeklychallenge-club-7a504ce6afeb14aa86c830260f0693262a20f9df.zip
Solutions for challenge #168
Diffstat (limited to 'challenge-168/roger-bell-west/python/ch-1.py')
-rwxr-xr-xchallenge-168/roger-bell-west/python/ch-1.py52
1 files changed, 52 insertions, 0 deletions
diff --git a/challenge-168/roger-bell-west/python/ch-1.py b/challenge-168/roger-bell-west/python/ch-1.py
new file mode 100755
index 0000000000..70bf8b3303
--- /dev/null
+++ b/challenge-168/roger-bell-west/python/ch-1.py
@@ -0,0 +1,52 @@
+#! /usr/bin/python3
+
+import unittest
+
+from math import sqrt,floor,log
+from collections import deque
+
+def isprime(candidate):
+ if candidate < 2:
+ return False
+ elif candidate==2:
+ return True
+ elif candidate==3:
+ return True
+ elif candidate % 2 == 0:
+ return False
+ elif candidate % 3 == 0:
+ return False
+ anchor = 0
+ limit = int(sqrt(candidate))
+ while True:
+ anchor += 6
+ for t in range(anchor-1,anchor+2,2):
+ if t > limit:
+ return True
+ if candidate % t == 0:
+ return False
+
+def perrinprime(n):
+ out = set()
+ seq = deque([3, 0, 2])
+ while True:
+ nv = seq[0] + seq[1]
+ seq.popleft()
+ seq.append(nv)
+ if isprime(nv):
+ out.add(nv)
+ if len(out) >= n:
+ break
+ o = list(out)
+ o.sort()
+ return o
+
+class TestPerrinprime(unittest.TestCase):
+
+ def test_ex1(self):
+ self.assertEqual(perrinprime(13),
+ [2, 3, 5, 7, 17, 29, 277, 367, 853, 14197,
+ 43721, 1442968193,
+ 792606555396977],'example 1')
+
+unittest.main()