Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
4 / 9 / 2
Регистрация: 05.10.2020
Сообщений: 51

Найти кратчайший путь

25.11.2021, 19:59. Показов 1602. Ответов 6

Студворк — интернет-сервис помощи студентам
Всем доброго дня и больше свободного времени!
Мне вот вдруг пришлось окунуться в мир алгоритмов, который я не очень люблю, ибо такими не особо владею. Прошу не начинать объяснять, что они мне нужны и тд, что многие делают, а помочь).
Задача - даны координаты точек (x, y) в виде массива с кортежами (в целом ввод не важен, это лишь часть программы, данные зависят от меня). Требуется кратчайшим образом пройтись по ВСЕМ координатам.
Нашел в инете только между 2 точкам, при этом не проходя другие.

Кому интересно - задача про облет кратчайшим путем квадрокоптером координат точек определенного цвета.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.11.2021, 19:59
Ответы с готовыми решениями:

Найти кратчайший путь между точками
Добрый день, начал изучать Python. И застрял на задачке по нахождении кратчайшего пути между точками (0,2), (2,5), (5,2),(6,6),(8,3)....

Найти кратчайший путь в системе координат
Сама задача такая: Дана координатная плоскость. Кролик стоит в точке (0;0). Он может прыгнуть вправо, влево, вниз или вверх на одну...

Найти самый кратчайший путь к вершине графа
V=(1,2,3,4) O=(1,3),(1,2),(2,4),(3,2),(3,4),(4,3) Нужен код питон

6
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38200 / 21132 / 4310
Регистрация: 12.02.2012
Сообщений: 34,738
Записей в блоге: 14
26.11.2021, 09:11
Сколько точек?
0
Эксперт Python
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
26.11.2021, 10:19
MaMush, может так?
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
def dist(p):
    
    return(abs(complex(p[0]-origin[0], p[1]-origin[1])))
 
 
n = 8 #int(input('количество точек: '))
points = {(3,4),(5,3),(7,4),(8,6),(7,8),(3,8),(2,6),(5,9)} #{tuple(map(float, input().split())) for _ in range(n)}
origin = (0,0)
origin = max(points, key=lambda a: dist(a))
res = [origin]
points.discard(origin)
 
for i in range(n-1):
    origin = min(points, key=lambda a: dist(a))
    res.append(origin)
    points.discard(origin)
 
print(res)
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
26.11.2021, 10:57
Цитата Сообщение от Catstail Посмотреть сообщение
Сколько точек?
если только на х, у будут ограничения.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38200 / 21132 / 4310
Регистрация: 12.02.2012
Сообщений: 34,738
Записей в блоге: 14
26.11.2021, 11:20
Gdez, говорят, что в данной задаче жадный алгоритм не дает полной оптимизации
0
Эксперт Python
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
26.11.2021, 11:50
Catstail, Но ведь по любому для каждой точки приходится находить ближайшую, перебирая оставшиеся...
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38200 / 21132 / 4310
Регистрация: 12.02.2012
Сообщений: 34,738
Записей в блоге: 14
26.11.2021, 16:25
Gdez, это и есть "жадный алгоритм". Он даст приемлемое решение, но не обеспечивает глобальной минимальности.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
26.11.2021, 16:25
Помогаю со студенческими работами здесь

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

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

Найти кратчайший путь в ориентированном графе с вершинами и дугами разных цветов
Не могу решить задачу, уже не знаю сколько времени долблюсь лбом об стену, ничего не выходит. Задание следующее: Дан ориентированный...

Кратчайший путь в графе
Добрый вечер, есть код, но его надо доработать. Не понимаю как и что. Задание: строка ввода # 1: n - целое число, показывающее, сколько...

Вычислить кратчайший путь
Помогите, пожалуйста, написать программу для вычисления кратчайшего пути от Spb до Kazan. Вот схема:...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru