mirror of
https://github.com/onyx-and-iris/grokking-algorithms.git
synced 2025-01-18 08:40:52 +00:00
add chapter9 exercises
This commit is contained in:
parent
49644bdbaf
commit
0cb2160e9e
BIN
chapter9/dijkstra1.png
Normal file
BIN
chapter9/dijkstra1.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 24 KiB |
BIN
chapter9/dijkstra2.png
Normal file
BIN
chapter9/dijkstra2.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 17 KiB |
BIN
chapter9/dijkstra3.png
Normal file
BIN
chapter9/dijkstra3.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 18 KiB |
73
chapter9/ex171a.py
Normal file
73
chapter9/ex171a.py
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
import logging
|
||||||
|
import math
|
||||||
|
|
||||||
|
logging.basicConfig(level=logging.DEBUG)
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
graph = {}
|
||||||
|
graph["start"] = {}
|
||||||
|
graph["start"]["a"] = 5
|
||||||
|
graph["start"]["b"] = 2
|
||||||
|
graph["a"] = {}
|
||||||
|
graph["a"]["b"] = 8
|
||||||
|
graph["a"]["c"] = 4
|
||||||
|
graph["a"]["d"] = 2
|
||||||
|
graph["b"] = {}
|
||||||
|
graph["b"]["a"] = 8
|
||||||
|
graph["b"]["d"] = 7
|
||||||
|
graph["c"] = {}
|
||||||
|
graph["c"]["d"] = 6
|
||||||
|
graph["c"]["fin"] = 3
|
||||||
|
graph["d"] = {}
|
||||||
|
graph["d"]["fin"] = 1
|
||||||
|
graph["fin"] = {}
|
||||||
|
|
||||||
|
costs = {}
|
||||||
|
costs["a"] = 5
|
||||||
|
costs["b"] = 2
|
||||||
|
costs["c"] = math.inf
|
||||||
|
costs["d"] = math.inf
|
||||||
|
costs["fin"] = math.inf
|
||||||
|
|
||||||
|
parents = {}
|
||||||
|
parents["a"] = "start"
|
||||||
|
parents["b"] = "start"
|
||||||
|
parents["c"] = None
|
||||||
|
parents["d"] = None
|
||||||
|
parents["fin"] = None
|
||||||
|
|
||||||
|
processed = set()
|
||||||
|
|
||||||
|
|
||||||
|
def find_lowest_cost_node(costs):
|
||||||
|
lowest_cost = math.inf
|
||||||
|
lowest_cost_node = None
|
||||||
|
for node in costs:
|
||||||
|
cost = costs[node]
|
||||||
|
if cost < lowest_cost and node not in processed:
|
||||||
|
lowest_cost = cost
|
||||||
|
lowest_cost_node = node
|
||||||
|
return lowest_cost_node
|
||||||
|
|
||||||
|
|
||||||
|
node = find_lowest_cost_node(costs)
|
||||||
|
while node is not None:
|
||||||
|
cost = costs[node]
|
||||||
|
neighbors = graph[node]
|
||||||
|
for n in neighbors.keys():
|
||||||
|
new_cost = cost + neighbors[n]
|
||||||
|
if costs[n] > new_cost:
|
||||||
|
costs[n] = new_cost
|
||||||
|
parents[n] = node
|
||||||
|
processed.add(node)
|
||||||
|
node = find_lowest_cost_node(costs)
|
||||||
|
|
||||||
|
print(f"lowest cost route: {costs['fin']}")
|
||||||
|
route = []
|
||||||
|
next = "fin"
|
||||||
|
while next != "start":
|
||||||
|
route.append(next)
|
||||||
|
next = parents[next]
|
||||||
|
route.append("start")
|
||||||
|
|
||||||
|
print(f"route: {list(reversed(route))}")
|
58
chapter9/ex171b.py
Normal file
58
chapter9/ex171b.py
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
import logging
|
||||||
|
import math
|
||||||
|
|
||||||
|
logging.basicConfig(level=logging.DEBUG)
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
graph = {}
|
||||||
|
graph["start"] = {}
|
||||||
|
graph["start"]["a"] = 10
|
||||||
|
graph["a"] = {}
|
||||||
|
graph["a"]["c"] = 20
|
||||||
|
graph["b"] = {}
|
||||||
|
graph["b"]["a"] = 1
|
||||||
|
graph["b"]["c"] = 1
|
||||||
|
graph["c"] = {}
|
||||||
|
graph["c"]["b"] = 1
|
||||||
|
graph["c"]["fin"] = 30
|
||||||
|
graph["fin"] = {}
|
||||||
|
|
||||||
|
costs = {}
|
||||||
|
costs["a"] = 10
|
||||||
|
costs["b"] = math.inf
|
||||||
|
costs["c"] = math.inf
|
||||||
|
costs["fin"] = math.inf
|
||||||
|
|
||||||
|
parents = {}
|
||||||
|
parents["a"] = "start"
|
||||||
|
parents["b"] = None
|
||||||
|
parents["c"] = None
|
||||||
|
parents["fin"] = None
|
||||||
|
|
||||||
|
processed = set()
|
||||||
|
|
||||||
|
|
||||||
|
def find_lowest_cost_node(costs):
|
||||||
|
lowest_cost = math.inf
|
||||||
|
lowest_cost_node = None
|
||||||
|
for node in costs:
|
||||||
|
cost = costs[node]
|
||||||
|
if cost < lowest_cost and node not in processed:
|
||||||
|
lowest_cost = cost
|
||||||
|
lowest_cost_node = node
|
||||||
|
return lowest_cost_node
|
||||||
|
|
||||||
|
|
||||||
|
node = find_lowest_cost_node(costs)
|
||||||
|
while node is not None:
|
||||||
|
cost = costs[node]
|
||||||
|
neighbors = graph[node]
|
||||||
|
for n in neighbors.keys():
|
||||||
|
new_cost = cost + neighbors[n]
|
||||||
|
if costs[n] > new_cost:
|
||||||
|
costs[n] = new_cost
|
||||||
|
parents[n] = node
|
||||||
|
processed.add(node)
|
||||||
|
node = find_lowest_cost_node(costs)
|
||||||
|
|
||||||
|
print(f"lowest cost route: {costs['fin']}")
|
59
chapter9/ex171c.py
Normal file
59
chapter9/ex171c.py
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
import logging
|
||||||
|
import math
|
||||||
|
|
||||||
|
logging.basicConfig(level=logging.DEBUG)
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
graph = {}
|
||||||
|
graph["start"] = {}
|
||||||
|
graph["start"]["a"] = 2
|
||||||
|
graph["start"]["b"] = 2
|
||||||
|
graph["a"] = {}
|
||||||
|
graph["a"]["b"] = 2
|
||||||
|
graph["b"] = {}
|
||||||
|
graph["b"]["c"] = 2
|
||||||
|
graph["b"]["fin"] = 2
|
||||||
|
graph["c"] = {}
|
||||||
|
graph["c"]["fin"] = 2
|
||||||
|
graph["fin"] = {}
|
||||||
|
|
||||||
|
|
||||||
|
costs = {}
|
||||||
|
costs["a"] = 2
|
||||||
|
costs["b"] = 2
|
||||||
|
costs["c"] = math.inf
|
||||||
|
costs["fin"] = math.inf
|
||||||
|
|
||||||
|
parents = {}
|
||||||
|
parents["a"] = "start"
|
||||||
|
parents["b"] = "start"
|
||||||
|
parents["c"] = None
|
||||||
|
parents["fin"] = None
|
||||||
|
|
||||||
|
processed = set()
|
||||||
|
|
||||||
|
|
||||||
|
def find_lowest_cost_node(costs):
|
||||||
|
lowest_cost = math.inf
|
||||||
|
lowest_cost_node = None
|
||||||
|
for node in costs:
|
||||||
|
cost = costs[node]
|
||||||
|
if cost < lowest_cost and node not in processed:
|
||||||
|
lowest_cost = cost
|
||||||
|
lowest_cost_node = node
|
||||||
|
return lowest_cost_node
|
||||||
|
|
||||||
|
|
||||||
|
node = find_lowest_cost_node(costs)
|
||||||
|
while node is not None:
|
||||||
|
cost = costs[node]
|
||||||
|
neighbors = graph[node]
|
||||||
|
for n in neighbors.keys():
|
||||||
|
new_cost = cost + neighbors[n]
|
||||||
|
if costs[n] > new_cost:
|
||||||
|
costs[n] = new_cost
|
||||||
|
parents[n] = node
|
||||||
|
processed.add(node)
|
||||||
|
node = find_lowest_cost_node(costs)
|
||||||
|
|
||||||
|
print(f"lowest cost route: {costs['fin']}")
|
10
chapter9/examples/heaptest.py
Normal file
10
chapter9/examples/heaptest.py
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
import heapq
|
||||||
|
|
||||||
|
customers = []
|
||||||
|
heapq.heappush(customers, (2, "Harry"))
|
||||||
|
heapq.heappush(customers, (3, "Charles"))
|
||||||
|
heapq.heappush(customers, (1, "Riya"))
|
||||||
|
heapq.heappush(customers, (4, "Stacy"))
|
||||||
|
|
||||||
|
while customers:
|
||||||
|
print(heapq.heappop(customers))
|
14
chapter9/examples/list.py
Normal file
14
chapter9/examples/list.py
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
customers = []
|
||||||
|
customers.append((2, "Harry")) # no sort needed here because 1 item.
|
||||||
|
customers.append((3, "Charles"))
|
||||||
|
customers.sort(reverse=True)
|
||||||
|
# Need to sort to maintain order
|
||||||
|
customers.append((1, "Riya"))
|
||||||
|
customers.sort(reverse=True)
|
||||||
|
# Need to sort to maintain order
|
||||||
|
customers.append((4, "Stacy"))
|
||||||
|
customers.sort(reverse=True)
|
||||||
|
|
||||||
|
while customers:
|
||||||
|
print(customers.pop(0))
|
||||||
|
# Will print names in the order: Stacy, Charles, Harry, Riya.
|
12
chapter9/examples/priorityqueuetest.py
Normal file
12
chapter9/examples/priorityqueuetest.py
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
from queue import PriorityQueue
|
||||||
|
|
||||||
|
customers = (
|
||||||
|
PriorityQueue()
|
||||||
|
) # we initialise the PQ class instead of using a function to operate upon a list.
|
||||||
|
customers.put((2, "Harry"))
|
||||||
|
customers.put((3, "Charles"))
|
||||||
|
customers.put((1, "Riya"))
|
||||||
|
customers.put((4, "Stacy"))
|
||||||
|
|
||||||
|
while customers:
|
||||||
|
print(customers.get())
|
78
chapter9/rama.py
Normal file
78
chapter9/rama.py
Normal file
@ -0,0 +1,78 @@
|
|||||||
|
import logging
|
||||||
|
import math
|
||||||
|
|
||||||
|
logging.basicConfig(level=logging.DEBUG)
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
### setup the graph
|
||||||
|
|
||||||
|
graph = {}
|
||||||
|
graph["start"] = {}
|
||||||
|
graph["start"]["a"] = 6
|
||||||
|
graph["start"]["b"] = 2
|
||||||
|
|
||||||
|
graph["a"] = {}
|
||||||
|
graph["a"]["fin"] = 1
|
||||||
|
|
||||||
|
graph["b"] = {}
|
||||||
|
graph["b"]["a"] = 3
|
||||||
|
graph["b"]["fin"] = 5
|
||||||
|
|
||||||
|
graph["fin"] = {}
|
||||||
|
|
||||||
|
### set up costs
|
||||||
|
|
||||||
|
costs = {}
|
||||||
|
costs["a"] = 6
|
||||||
|
costs["b"] = 2
|
||||||
|
costs["fin"] = math.inf
|
||||||
|
|
||||||
|
### setup parents
|
||||||
|
|
||||||
|
parents = {}
|
||||||
|
parents["a"] = "start"
|
||||||
|
parents["b"] = "start"
|
||||||
|
parents["fin"] = None
|
||||||
|
|
||||||
|
### our processed queue
|
||||||
|
|
||||||
|
processed = set()
|
||||||
|
|
||||||
|
### algorithm
|
||||||
|
|
||||||
|
|
||||||
|
def find_lowest_cost_node(costs):
|
||||||
|
lowest_cost = math.inf
|
||||||
|
lowest_cost_node = None
|
||||||
|
for node in costs:
|
||||||
|
cost = costs[node]
|
||||||
|
if cost < lowest_cost and node not in processed:
|
||||||
|
lowest_cost = cost
|
||||||
|
lowest_cost_node = node
|
||||||
|
return lowest_cost_node
|
||||||
|
|
||||||
|
|
||||||
|
node = find_lowest_cost_node(costs) # find lowest-cost node not already processed
|
||||||
|
while node is not None:
|
||||||
|
cost = costs[node]
|
||||||
|
neighbors = graph[node]
|
||||||
|
logger.debug(f"node: {node} cost: {cost} neighbor: {neighbors}")
|
||||||
|
for n in neighbors.keys():
|
||||||
|
new_cost = cost + neighbors[n]
|
||||||
|
if costs[n] > new_cost:
|
||||||
|
costs[n] = new_cost
|
||||||
|
parents[n] = node
|
||||||
|
processed.add(node)
|
||||||
|
logger.debug(f"processed: {processed}")
|
||||||
|
node = find_lowest_cost_node(costs)
|
||||||
|
|
||||||
|
|
||||||
|
route = []
|
||||||
|
next = "fin"
|
||||||
|
while next != "start":
|
||||||
|
route.append(next)
|
||||||
|
next = parents[next]
|
||||||
|
route.append("start")
|
||||||
|
|
||||||
|
print(f"route: {list(reversed(route))}")
|
Loading…
Reference in New Issue
Block a user