diff options
| author | Mohammad S Anwar <Mohammad.Anwar@yahoo.com> | 2022-01-06 20:17:20 +0000 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-01-06 20:17:20 +0000 |
| commit | 786f21aed588d59411c670d209123721bd492d57 (patch) | |
| tree | 6e63e5ca51c8d2305bf3f277ca181ab1214691fa /challenge-003/abigail/python/ch-1.py | |
| parent | b900311560a2aaccd86c911d362838090ca1e2d9 (diff) | |
| parent | 5ef21313761723d1a1e68fd07d770492a7365d56 (diff) | |
| download | perlweeklychallenge-club-786f21aed588d59411c670d209123721bd492d57.tar.gz perlweeklychallenge-club-786f21aed588d59411c670d209123721bd492d57.tar.bz2 perlweeklychallenge-club-786f21aed588d59411c670d209123721bd492d57.zip | |
Merge pull request #5481 from Abigail/abigail/week-003
Abigail/week 003
Diffstat (limited to 'challenge-003/abigail/python/ch-1.py')
| -rw-r--r-- | challenge-003/abigail/python/ch-1.py | 40 |
1 files changed, 23 insertions, 17 deletions
diff --git a/challenge-003/abigail/python/ch-1.py b/challenge-003/abigail/python/ch-1.py index 30b41dd8fe..8b3ac1e035 100644 --- a/challenge-003/abigail/python/ch-1.py +++ b/challenge-003/abigail/python/ch-1.py @@ -1,27 +1,33 @@ #!/opt/local/bin/python # -# See ../READ.md +# See https://theweeklychallenge.org/blog/perl-weekly-challenge-003 # # -# Run as python ch-1.py < input-file +# Run as: python ch-1.py < input-file # import fileinput -for line in fileinput . input (): - max = int (line) - # - # Python does not have a for (;;) style loop - # - base2 = 1 - while base2 <= max: - base3 = base2 - while base3 <= max: - base5 = base3 - while base5 <= max: - print base5 - base5 *= 5 - base3 *= 3 - base2 *= 2 +ugly = [1] +next_2 = 0 +next_3 = 0 +next_5 = 0 + + +for n in fileinput . input (): + n = int (n) + while len (ugly) < n: + ugly . append (min ([2 * ugly [next_2], + 3 * ugly [next_3], + 5 * ugly [next_5]])) + + if 2 * ugly [next_2] <= ugly [-1]: + next_2 = next_2 + 1 + if 3 * ugly [next_3] <= ugly [-1]: + next_3 = next_3 + 1 + if 5 * ugly [next_5] <= ugly [-1]: + next_5 = next_5 + 1 + + print (ugly [n - 1]) |
