From 4e2479b8079bf4a627a89b38523a38134d90c081 Mon Sep 17 00:00:00 2001 From: AbreuOliver Date: Fri, 20 Nov 2020 18:24:31 -0500 Subject: [PATCH 1/2] Initial commit --- adv.py | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/adv.py b/adv.py index 84f031836..278cd446f 100644 --- a/adv.py +++ b/adv.py @@ -29,7 +29,12 @@ # traversal_path = ['n', 'n'] traversal_path = [] +# <-- START CODE +# Initialize the graph +graph = {} + +# --> END CODE # TRAVERSAL TEST - DO NOT MODIFY visited_rooms = set() From aa458ec96cb11f364e02766fa04c6cbb9fdbe0f7 Mon Sep 17 00:00:00 2001 From: AbreuOliver Date: Sat, 21 Nov 2020 00:09:02 -0500 Subject: [PATCH 2/2] feat(adv.py): Proposes passing solution --- adv.py | 58 +++++++++++++++++++++++++++++++++++++++++++++------------- 1 file changed, 45 insertions(+), 13 deletions(-) diff --git a/adv.py b/adv.py index 278cd446f..b07af36e8 100644 --- a/adv.py +++ b/adv.py @@ -30,10 +30,42 @@ traversal_path = [] # <-- START CODE - -# Initialize the graph -graph = {} - +visited = {} + +oppostie_dir = { + 'n': 's', 's': 'n', 'e': 'w', 'w': 'e' + } + +backtrack_route = [None] + +# while number of rooms visited is less than total number of rooms +while len(visited) < len(room_graph) - 1: + # if the current room has not yet been visited + if player.current_room.id not in visited: + # get all the exits of the current room + visited[player.current_room.id] = player.current_room.get_exits() + # if we have come in from another room, + if backtrack_route[-1]: + # remove the direction we just came from the current room (in visited rooms) + visited[player.current_room.id].remove(backtrack_route[-1]) + else: + continue + # while the current room you are in does not have any unvisted exits + while len(visited[player.current_room.id]) == 0: + # the previous path is equal to the last direction in the backtrack route + previous_path = backtrack_route.pop() + # add to the traversal path the previous path + traversal_path.append(previous_path) + # travel the previous path + player.travel(previous_path) + # next direction is equal to the most recently visited room + next_direction = visited[player.current_room.id].pop() + # add the next direction to the traversal path + traversal_path.append(next_direction) + # add to the backtracking route by adding the opposite direction to the next direction + backtrack_route.append(oppostie_dir[next_direction]) + # go in the next direction! + player.travel(next_direction) # --> END CODE # TRAVERSAL TEST - DO NOT MODIFY @@ -56,12 +88,12 @@ ####### # UNCOMMENT TO WALK AROUND ####### -player.current_room.print_room_description(player) -while True: - cmds = input("-> ").lower().split(" ") - if cmds[0] in ["n", "s", "e", "w"]: - player.travel(cmds[0], True) - elif cmds[0] == "q": - break - else: - print("I did not understand that command.") +# player.current_room.print_room_description(player) +# while True: +# cmds = input("-> ").lower().split(" ") +# if cmds[0] in ["n", "s", "e", "w"]: +# player.travel(cmds[0], True) +# elif cmds[0] == "q": +# break +# else: +# print("I did not understand that command.")