diff options
| author | Paulo Custodio <pauloscustodio@gmail.com> | 2022-04-12 18:56:29 +0100 |
|---|---|---|
| committer | Paulo Custodio <pauloscustodio@gmail.com> | 2022-04-12 18:56:29 +0100 |
| commit | 49f7f459092f538b5468e255ff4e8ebac490d70a (patch) | |
| tree | fa4a94a8207a58a56d4dca98ff22d39bed047f6e /challenge-159/roger-bell-west/python/ch-1.py | |
| parent | 1711da4f548d3134248cd5e02a13d71762d5e4cb (diff) | |
| parent | 72ba70a96cfd587443c3eaa0f5ba02e3557f4b82 (diff) | |
| download | perlweeklychallenge-club-49f7f459092f538b5468e255ff4e8ebac490d70a.tar.gz perlweeklychallenge-club-49f7f459092f538b5468e255ff4e8ebac490d70a.tar.bz2 perlweeklychallenge-club-49f7f459092f538b5468e255ff4e8ebac490d70a.zip | |
Merge remote-tracking branch 'upstream/master'
# Conflicts:
# challenge-160/paulo-custodio/Makefile
Diffstat (limited to 'challenge-159/roger-bell-west/python/ch-1.py')
| -rwxr-xr-x | challenge-159/roger-bell-west/python/ch-1.py | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/challenge-159/roger-bell-west/python/ch-1.py b/challenge-159/roger-bell-west/python/ch-1.py new file mode 100755 index 0000000000..d6e05acf97 --- /dev/null +++ b/challenge-159/roger-bell-west/python/ch-1.py @@ -0,0 +1,50 @@ +#! /usr/bin/python3 + +import unittest + +from math import gcd +from functools import reduce + +def lcm(m,n): + return m//gcd(m,n)*n + +def lcmseries(s): + return reduce(lcm, s) + +def farey(n): + l=lcmseries(range(2,n+1)) + d=dict() + s=[] + for i in range(1,n+1): + m=l // i + for j in range(0,i+1): + k=m*j + if not k in d: + d[k]=[j,i] + s.append(k) + s.sort() + return [d[i] for i in s] + +class TestFarey(unittest.TestCase): + + def test_ex1(self): + self.assertEqual(farey(5), + [[0,1], [1,5], [1,4], [1,3], [2,5], [1,2], + [3,5], [2,3], [3,4], [4,5], [1,1]], + 'example 1') + + def test_ex2(self): + self.assertEqual(farey(7), + [[0,1], [1,7], [1,6], [1,5], [1,4], [2,7], + [1,3], [2,5], [3,7], [1,2], [4,7], [3,5], + [2,3], [5,7], [3,4], [4,5], [5,6], [6,7], + [1,1]], + 'example 2') + + def test_ex3(self): + self.assertEqual(farey(4), + [[0,1], [1,4], [1,3], [1,2], [2,3], [3,4], + [1,1]], + 'example 3') + +unittest.main() |
