aboutsummaryrefslogtreecommitdiff
path: root/challenge-121/abigail/python/ch-2.py
diff options
context:
space:
mode:
authorMohammad S Anwar <Mohammad.Anwar@yahoo.com>2021-07-18 18:30:11 +0100
committerGitHub <noreply@github.com>2021-07-18 18:30:11 +0100
commitc776d5869239f18013d99cdcd6bc91da1dee6d99 (patch)
treee47f9f1558a6718a1e371520a67a6c0864f7c8d3 /challenge-121/abigail/python/ch-2.py
parent1857a19609bd20d84e86e446c37516a06cad20d0 (diff)
parent298efeceb150a2921d14b26920b821ccbea477bf (diff)
downloadperlweeklychallenge-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.py40
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)))