Форум программистов, компьютерный форум, киберфорум
Python: Tkinter
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 19.12.2021
Сообщений: 1

Нужно найти оптимальный путь для дракона

19.12.2021, 16:32. Показов 535. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно найти оптимальный путь для дракона. Оптимальный путь заключается в том что нужно самым коротким путём до правого нижнего угла, собрать все хорошие сокровища, избегая плохие. Если слишком много писать кода, то можно просто пройти до правого нижнего угла, избегая плохие сокровища, ну или скажите хотя бы как это должно примерно выглядеть или тп.

Вот мой код:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
import random
import time
from tkinter import *
 
 
def draw_circle():
    x = c.coords(id_img)[0]
    y = c.coords(id_img)[1]
    r = (img_obj.width() + 14) / 8
    c.create_oval(x - r, y - r, x + r, y + r, fill='#FF8700')
    return
 
 
def delete_image(dx, dy):
    x = c.coords(id_img)[0] + dx
    y = c.coords(id_img)[1] + dy
    c.create_rectangle(x - img_size // 2, y - img_size // 2, x + img_size // 2, y + img_size // 2,
                       fill='#476BD6', outline='')
 
 
def move_dxdy(n, dx, dy):
    for i in range(n):
        time.sleep(0.5)
        delete_image(dx, dy)
        win.update()
        draw_circle()
        c.move(id_img, dx, dy)
        c.tag_raise(id_img)
        win.update()
 
 
win_size = 660
cell = 10
cell_size = win_size // cell
indent = cell_size // 8
img_size = cell_size - indent * 2
up = True
 
start_hor = 1
start_vert = 1
 
cur_hor = 1
cur_vert = 1
 
win = Tk()
win.geometry(str(win_size) + 'x' + str(win_size))
win.title('Миссия №8_2 Команда №53')
win.resizable(width=False, height=False)
c = Canvas(width=win_size, height=win_size, bg='#476BD6')
c.pack()
 
for coordinate in range(0, win_size + 1, cell_size):
    c.create_line(0, coordinate, win_size, coordinate, fill='#FF8700')
    c.create_line(coordinate, 0, coordinate, win_size, fill='#FF8700')
img_obj = PhotoImage(file="Logo_53.png")
treasure = PhotoImage(file='treasure.png')
bad_treasure = PhotoImage(file='bad_treasure.png')
img_obj = img_obj.zoom(cell_size - indent * 2)
img_obj = img_obj.subsample(50)
treasure = treasure.zoom(cell_size - indent * 2)
treasure = treasure.subsample(50)
bad_treasure = bad_treasure.zoom(cell_size - indent * 2)
bad_treasure = bad_treasure.subsample(50)
id_img = c.create_image(indent + (cell_size * (start_hor - 1)) + img_size // 2,
                        indent + ((start_vert - 1) * cell_size) + img_size // 2, image=img_obj, anchor='center')
win.update()
 
a = [[0] * cell for b in range(cell)]
 
for i in range(cell):
    for j in range(cell):
        v = random.randint(1, 4)
        if (v == 1) and not ((i == start_hor) and (j == start_vert)):
            a[i][j] = 1
        v = random.randint(1, 4)
        if (v == 2) and not ((i == 0) and (j == 9)):
            a[i][j] = 2
 
for i in range(cell):
    for j in range(cell):
        if a[i][j] == 1:
            c.create_image(indent + (cell_size * j), indent + (cell_size * i), image=treasure, anchor='nw')
        if a[i][j] == 2:
            c.create_image(indent + (cell_size * j), indent + (cell_size * i), image=bad_treasure, anchor='nw')
        win.update()
 
win.mainloop()
Вот все файлы используемые в коде
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
19.12.2021, 16:32
Ответы с готовыми решениями:

Найти оптимальный путь
Дан текстовый файл, в нём на каждой строке записаны координаты точек на плоскости. Пример: 1 5 3 7 12 35 Нужно найти минимальную...

Найти оптимальный путь по графу
Здравствуйте! Всегда относился с неким страхом к рекурсивным функциям, мне они не очень понятны. Теперь нужно написать программу, которая...

Найти оптимальный путь в двумерном массиве
Здравствуйте! Имеет двумерный массив пользовательского класса TechnicalRealization, в котором у каждого элемента есть 2 поля: failure и...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.12.2021, 16:32
Помогаю со студенческими работами здесь

Найти методом потенциалов оптимальный путь от пункта 1 к пункту 9
Найти методом потенциалов оптимальный путь от пункта 1 к пункту 9(помогите пожалуйста)!

Найти оптимальный путь путешественника прохождение которого дает максимальную сумму призов
Путешественник выходит из нижней левой клетки доски и уходит в верхнюю правую клетку. Ходить он может вправо, вверх и по диагонали на...

Требуется провести оптимальный путь по вершинам на поверхности, оптимальным считается путь с наименьшим перепадом высот
Как выглядит задание: Разрабатывается настольная игра для детей, в которую входит макет поверхности планеты. Макет имеет форму...

Стержень нужно разрезать на стержни. Найти оптимальный вариант раскроя
Вот условие задачки: Стержень длиной l0 нужно разрезать на стержни длиной l1,l2...lk. Количество отрезков каждого типа не ограничено. Найти...

Оптимальный путь
Для решения большого класса задач про поиск оптимального маршрута, анализа дорожного траффика и т.д. используется математический аппарат,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере нетипового документа выдачи шин для спецтехники с табличной частью, разработанного в конфигурации КА2. Данные берутся из. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru