diff options
| author | Roger Bell_West <roger@firedrake.org> | 2021-08-10 23:32:55 +0100 |
|---|---|---|
| committer | Roger Bell_West <roger@firedrake.org> | 2021-08-10 23:32:55 +0100 |
| commit | 851399b5d2e46d92aafc22871091dd4ac86f6cf8 (patch) | |
| tree | 81fa79f5825680e3fedbc37b6676026588fecd58 /challenge-125/roger-bell-west/python/ch-2.py | |
| parent | dae33f10b00beaf02883597401ede84ddcc3b77f (diff) | |
| download | perlweeklychallenge-club-851399b5d2e46d92aafc22871091dd4ac86f6cf8.tar.gz perlweeklychallenge-club-851399b5d2e46d92aafc22871091dd4ac86f6cf8.tar.bz2 perlweeklychallenge-club-851399b5d2e46d92aafc22871091dd4ac86f6cf8.zip | |
Answers for challenge #125 (amended Tuesday evening)
Diffstat (limited to 'challenge-125/roger-bell-west/python/ch-2.py')
| -rwxr-xr-x | challenge-125/roger-bell-west/python/ch-2.py | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/challenge-125/roger-bell-west/python/ch-2.py b/challenge-125/roger-bell-west/python/ch-2.py new file mode 100755 index 0000000000..70df3a8337 --- /dev/null +++ b/challenge-125/roger-bell-west/python/ch-2.py @@ -0,0 +1,35 @@ +#! /usr/bin/python3 + +import unittest + +from math import degrees,atan2 + +def btd(tree): + st=len(tree) + depth=[0]*st + diameter=[0]*st + for i in range(st-1,-1,-1): + if tree[i] != 0: + a=i*2+1 + b=a+1 + if b < st: + depth[i]=1+max(depth[a],depth[b]) + diameter[i]=max( + depth[a]+depth[b], + diameter[a], + diameter[b] + ) + else: + depth[i]=1 + return diameter[0] + +class TestBtd(unittest.TestCase): + + def test_ex1(self): + self.assertEqual(btd([1, + 2,5, + 3,4,6,7, + 0,0,0,0,0,0,8,10, + 0,0,0,0,0,0,0,0,0,0,0,0,9,0,0,0]),6,'example 1') + +unittest.main() |
