diff options
| author | Michael Manring <michael@manring> | 2024-03-22 01:16:53 +1100 |
|---|---|---|
| committer | Michael Manring <michael@manring> | 2024-03-22 01:18:46 +1100 |
| commit | 1663b8d08a3d61bc8ae9fea9352efdd9cb892cc8 (patch) | |
| tree | ed6aa2bacba8df95929019a3030061f6cfe69e83 /challenge-261 | |
| parent | 5bdb6ed8347dae7adc19d0403759d70f47f047fc (diff) | |
| download | perlweeklychallenge-club-1663b8d08a3d61bc8ae9fea9352efdd9cb892cc8.tar.gz perlweeklychallenge-club-1663b8d08a3d61bc8ae9fea9352efdd9cb892cc8.tar.bz2 perlweeklychallenge-club-1663b8d08a3d61bc8ae9fea9352efdd9cb892cc8.zip | |
pwc261 solution in python
Diffstat (limited to 'challenge-261')
| -rw-r--r-- | challenge-261/pokgopun/python/ch-1.py | 71 | ||||
| -rw-r--r-- | challenge-261/pokgopun/python/ch-2.py | 71 |
2 files changed, 142 insertions, 0 deletions
diff --git a/challenge-261/pokgopun/python/ch-1.py b/challenge-261/pokgopun/python/ch-1.py new file mode 100644 index 0000000000..073ab918fa --- /dev/null +++ b/challenge-261/pokgopun/python/ch-1.py @@ -0,0 +1,71 @@ +### https://theweeklychallenge.org/blog/perl-weekly-challenge-261/ +""" + +Task 1: Element Digit Sum + +Submitted by: [45]Mohammad Sajid Anwar + __________________________________________________________________ + + You are given an array of integers, @ints. + + Write a script to evaluate the absolute difference between element and + digit sum of the given array. + +Example 1 + +Input: @ints = (1,2,3,45) +Output: 36 + +Element Sum: 1 + 2 + 3 + 45 = 51 +Digit Sum: 1 + 2 + 3 + 4 + 5 = 15 +Absolute Difference: | 51 - 15 | = 36 + +Example 2 + +Input: @ints = (1,12,3) +Output: 9 + +Element Sum: 1 + 12 + 3 = 16 +Digit Sum: 1 + 1 + 2 + 3 = 7 +Absolute Difference: | 16 - 7 | = 9 + +Example 3 + +Input: @ints = (1,2,3,4) +Output: 0 + +Element Sum: 1 + 2 + 3 + 4 = 10 +Digit Sum: 1 + 2 + 3 + 4 = 10 +Absolute Difference: | 10 - 10 | = 0 + +Example 4 + +Input: @ints = (236, 416, 336, 350) +Output: 1296 + +Task 2: Multiply by Two +""" +### solution by pokgopun@gmail.com + +from itertools import chain + +def EDS(ints: tuple): + return sum(ints) - sum( + int(e) for e in chain.from_iterable( + str(i) for i in ints + ) + ) + +import unittest + +class TestEDS(unittest.TestCase): + def test(self): + for inpt, otpt in { + (1,2,3,45): 36, + (1,12,3): 9, + (1,2,3,4): 0, + (236, 416, 336, 350): 1296, + }.items(): + self.assertEqual(EDS(inpt),otpt) + +unittest.main() diff --git a/challenge-261/pokgopun/python/ch-2.py b/challenge-261/pokgopun/python/ch-2.py new file mode 100644 index 0000000000..f8e85bf717 --- /dev/null +++ b/challenge-261/pokgopun/python/ch-2.py @@ -0,0 +1,71 @@ +### https://theweeklychallenge.org/blog/perl-weekly-challenge-261/ +""" + +Task 2: Multiply by Two + +Submitted by: [46]Mohammad Sajid Anwar + __________________________________________________________________ + + You are given an array of integers, @ints and an integer $start.. + + Write a script to do the followings: +a) Look for $start in the array @ints, if found multiply the number by 2 +b) If not found stop the process otherwise repeat + + In the end return the final value. + +Example 1 + +Input: @ints = (5,3,6,1,12) and $start = 3 +Output: 24 + +Step 1: 3 is in the array so 3 x 2 = 6 +Step 2: 6 is in the array so 6 x 2 = 12 +Step 3: 12 is in the array so 12 x 2 = 24 + +24 is not found in the array so return 24. + +Example 2 + +Input: @ints = (1,2,4,3) and $start = 1 +Output: 8 + +Step 1: 1 is in the array so 1 x 2 = 2 +Step 2: 2 is in the array so 2 x 2 = 4 +Step 3: 4 is in the array so 4 x 2 = 8 + +8 is not found in the array so return 8. + +Example 3 + +Input: @ints = (5,6,7) and $start = 2 +Output: 2 + +2 is not found in the array so return 2. + __________________________________________________________________ + + Last date to submit the solution 23:59 (UK Time) Sunday 24th March + 2024. + __________________________________________________________________ + +SO WHAT DO YOU THINK ? +""" +### solution by pokgopun@gmail.com + +def MB2(ints: tuple, start: int): + while start in ints: + start *= 2 + return start + +import unittest + +class TestMB2(unittest.TestCase): + def test(self): + for (ints, start), otpt in { + ((5,3,6,1,12),3): 24, + ((1,2,4,3),1): 8, + ((5,6,7),2): 2, + }.items(): + self.assertEqual(MB2(ints,start), otpt) + +unittest.main() |
