Skip to content

Rozwiązania - Python

Zadanie 1

from math import inf

def dfs(x, y, maze, length):
    if maze[x][y] == 9:
        return length

    if maze[x][y] == 0:
        return inf

    maze[x][y] = 0

    return min(
        dfs(x - 1, y, maze, length + 1),
        dfs(x + 1, y, maze, length + 1),
        dfs(x, y - 1, maze, length + 1),
        dfs(x, y + 1, maze, length + 1),
    )

with open("maze.txt") as file:
    file.readline()
    maze = [list(map(int, list(line.strip()))) for line in file]

x, y = 1, 1
print(dfs(x, y, maze, 0))

Zadanie 2

from math import inf

def dfs_cost(x, y, maze, cost):
    if maze[x][y] == 9:
        return cost - 1

    if maze[x][y] == 0:
        return inf

    cost += maze[x][y]
    maze[x][y] = 0

    return min(
        dfs_cost(x - 1, y, maze, cost),
        dfs_cost(x + 1, y, maze, cost),
        dfs_cost(x, y - 1, maze, cost),
        dfs_cost(x, y + 1, maze, cost),
    )

with open("maze.txt") as file:
    file.readline()
    maze = [list(map(int, list(line.strip()))) for line in file]

x, y = 1, 1
print(dfs_cost(x, y, maze, 0))

Zadanie 3

from math import inf

def dfs(x, y, maze, length):
    if maze[x][y] == 9:
        return length

    if maze[x][y] == 0:
        return inf

    maze[x][y] = 0

    return min(
        dfs(x - 1, y, maze, length + 1),
        dfs(x + 1, y, maze, length + 1),
        dfs(x, y - 1, maze, length + 1),
        dfs(x, y + 1, maze, length + 1),
    )

with open("maze.txt") as file:
    width, height = map(int, file.readline().split())
    maze_str = file.read().strip()
    fields_count = width * height - maze_str.count("0")
    maze = [list(map(int, list(line.strip()))) for line in maze_str.split("\n")]

x, y = 1, 1
print(fields_count - dfs(x, y, maze, 0) - 1)

Zadanie 4

with open("maze.txt") as file:
    file.readline()
    maze_sum = sum([sum(map(int, list(line.strip()))) for line in file])

print(maze_sum - 10)

Zadanie 5

with open("maze.txt") as file:
    width, height = map(int, file.readline().split())
    maze = [list(map(int, list(line.strip()))) for line in file]

x, y = 1, 1
result = 0
while x != width - 1 and y != height - 1:
    if maze[x + 1][y] > maze[x][y + 1]:
        x += 1
    else:
        y += 1

    result += maze[x][y]

while x != width - 1:
    x += 1
    result += maze[x][y]

while y != height - 1:
    y += 1
    result += maze[x][y]

print(result - 9)

Zadanie 6

with open("maze.txt") as file:
    width, height = map(int, file.readline().split())
    maze = [list(map(int, list(line.strip()))) for line in file]

for x in range(height - 2, 0, -1):
    for y in range(width - 2, 0, -1):
        maze[x][y] += max(maze[x + 1][y], maze[x][y + 1])

print(maze[1][1] - 10)