diff options
| author | Mohammad S Anwar <Mohammad.Anwar@yahoo.com> | 2021-07-18 18:30:11 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-07-18 18:30:11 +0100 |
| commit | c776d5869239f18013d99cdcd6bc91da1dee6d99 (patch) | |
| tree | e47f9f1558a6718a1e371520a67a6c0864f7c8d3 /challenge-121/abigail/python/ch-2.py | |
| parent | 1857a19609bd20d84e86e446c37516a06cad20d0 (diff) | |
| parent | 298efeceb150a2921d14b26920b821ccbea477bf (diff) | |
| download | perlweeklychallenge-club-c776d5869239f18013d99cdcd6bc91da1dee6d99.tar.gz perlweeklychallenge-club-c776d5869239f18013d99cdcd6bc91da1dee6d99.tar.bz2 perlweeklychallenge-club-c776d5869239f18013d99cdcd6bc91da1dee6d99.zip | |
Merge pull request #4548 from Abigail/abigail/week-121
Abigail/week 121
Diffstat (limited to 'challenge-121/abigail/python/ch-2.py')
| -rw-r--r-- | challenge-121/abigail/python/ch-2.py | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/challenge-121/abigail/python/ch-2.py b/challenge-121/abigail/python/ch-2.py new file mode 100644 index 0000000000..c01e43bf43 --- /dev/null +++ b/challenge-121/abigail/python/ch-2.py @@ -0,0 +1,40 @@ +#!/opt/local/bin/python + +# +# See ../README.md +# + +# +# Run as: python ch-2.py < input-file +# + +import fileinput + +def shortest_path (matrix, start, to, exclude): + if 1 + len (exclude . keys ()) == len (matrix): + return matrix [start] [to], [to] + + shortest = 9999999999999999999 + sh_path = [] + new_exclude = exclude . copy () + new_exclude [start] = 1 + + for next in range (len (matrix)): + if next == start or next == to or next in exclude: + continue + length, path = shortest_path (matrix, next, to, new_exclude) + if shortest > length + matrix [start] [next]: + shortest = length + matrix [start] [next] + sh_path = [next] + path + + return shortest, sh_path + + +matrix = [] +for line in fileinput . input (): + matrix . append (list (map (lambda x: int (x), line . split (" ")))) + +length, path = shortest_path (matrix, 0, 0, {}) + +print (length) +print (0, " " . join (map (lambda x: str (x), path))) |
