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

Нахождение расстояния между двумя точками

05.02.2023, 16:42. Показов 12986. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В списке coords лежат 2 кортежа, каждый из которых является координатами точек A и B соответственно. Напишите функцию, которая ищет расстояние между этими точками.

Найти расстояние между двумя точками по формулам на плоскости и в пространстве

Рекомендации к выполнению:

Используйте функцию zip, чтобы итерироваться одновременно по координатам точки A и точки B.
Квадратный корень числа можно вычислить, возведя его в степень 0.5.

coords1 = [(1, 10), (1, 11)]
coords2 = [(0, 20), (20, 20)]
coords3 = [(100, 91, 87), (80, 35, 70)]
coords4 = [(0, 100, 20), (0, 0, 80)]

Помогите,пожалуйста, найти решение. Я совсем запуталась и теперь вообще ничего не выходит
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.02.2023, 16:42
Ответы с готовыми решениями:

Решение задачи с нахождением расстояния между двумя точками в 3D пространстве
Здравствуйте! У меня возникла проблема с задачей. По условию задачи даны две точки p1, p2 с координатами xyz, нужно найти расстояние между...

Нахождение дистанции между двумя точками
Создайте класс Point. У этого класса должны быть • метод set coordinates, который принимает координаты по х и по у, и сохраняет их в...

Рассчитать расстояния между точками
Даны 5 точек в координатной форме. Посчитать расстояние попарно. Сравнить полученные расстояния, вывести координаты точек, определить...

6
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
05.02.2023, 17:25
Лучший ответ Сообщение было отмечено Marika1986 как решение

Решение

Python
1
2
3
4
5
6
7
8
9
10
11
from math import dist
 
coords1 = [(1, 10), (1, 11)]
coords2 = [(0, 20), (20, 20)]
coords3 = [(100, 91, 87), (80, 35, 70)]
coords4 = [(0, 100, 20), (0, 0, 80)]
 
print(dist(*coords1))
print(dist(*coords2))
print(dist(*coords3))
print(dist(*coords4))
3
0 / 0 / 0
Регистрация: 05.02.2023
Сообщений: 2
05.02.2023, 17:39  [ТС]
Огромное спасибо за ответ))))Ваше решение лаконичное, компактное. Но мы еще не походили библиотеку math. Требование задания решить через функцию и используя zip. Но спасибо, что отозвались)))
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
05.02.2023, 17:43
откройте модуль math и посмотрите что там написано:
Python
1
2
3
4
5
6
7
8
9
10
11
def dist(*args, **kwargs): # real signature unknown
    """
    Return the Euclidean distance between two points p and q.
    
    The points should be specified as sequences (or iterables) of
    coordinates.  Both inputs must have the same dimension.
    
    Roughly equivalent to:
        sqrt(sum((px - qx) ** 2.0 for px, qx in zip(p, q)))
    """
    pass
Добавлено через 23 секунды
Python
1
sqrt(sum((px - qx) ** 2.0 for px, qx in zip(p, q)))
2
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38203 / 21135 / 4310
Регистрация: 12.02.2012
Сообщений: 34,740
Записей в блоге: 14
06.02.2023, 07:40
Marika1986, вот:

Python
1
2
3
4
5
6
7
8
9
c1 = [(1, 10), (1, 11)]
c2 = [(0, 20), (20, 20)]
c3 = [(100, 91, 87), (80, 35, 70)]
c4 = [(0, 100, 20), (0, 0, 80)]
 
d=0
for pair in zip(*c1):    # подставляй сюда вместо c1 - c2..c4 - получишь нужное расстояние
    d+=(pair[0]-pair[1])**2
print(d**0.5)
1
0 / 0 / 0
Регистрация: 15.12.2024
Сообщений: 3
22.12.2024, 15:51
Python
1
2
3
4
5
6
7
8
9
10
11
12
coords1 = [(1, 10), (1, 11)]
coords2 = [(0, 20), (20, 20)]
coords3 = [(100, 91, 87), (80, 35, 70)]
coords4 = [(0, 100, 20), (0, 0, 80)]
 
coords = [coords1] + [coords2] + [coords3] + [coords4]
d=0
for i in coords:
    for j in zip(*i):    
        d+=(j[0]-j[1])**2
    print(d**0.5)
    d = 0
0
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6241 / 2954 / 1047
Регистрация: 01.06.2021
Сообщений: 10,979
22.12.2024, 17:39
Цитата Сообщение от eaa Посмотреть сообщение
Python
1
sqrt(sum((px - qx) ** 2.0 for px, qx in zip(p, q)))
для sqrt тоже нужен math. Но ТС просит не использовать данный модуль. Наверное, нужно было **0.5 предлагать.

FunFox, d=0 можно написать в начале тела цикла, тогда код станет на одну строку короче

Python
1
2
3
4
5
6
7
8
9
10
coords1 = [(1, 10), (1, 11)]
coords2 = [(0, 20), (20, 20)]
coords3 = [(100, 91, 87), (80, 35, 70)]
coords4 = [(0, 100, 20), (0, 0, 80)]
 
for i in [coords1] + [coords2] + [coords3] + [coords4]:
    d=0
    for j in zip(*i):    
        d+=(j[0]-j[1])**2
    print(d**0.5)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.12.2024, 17:39
Помогаю со студенческими работами здесь

Расстояние между двумя точками
Прошу помощи, я решил задачу, как знал, а именно: def distance_space(coords): distance_x = () distance_y = () for i in...

Расстояние между двумя точками
Напишите код, который находит расстояние между двумя точками на плоскости по координатам этих точек. Найдите расстояние между точками с...

Максимальное расстояние между двумя точками
Даны число n и координаты n точек. Создать приложение, которое определит максимальное расстояние между двумя точками и укажет между...

Найти расстояние между двумя точками с заданными координатами
Найти расстояние между двумя точками с заданными координатами х1, и х2 на числовой оси

Расстояние между двумя точками в декартовой системе координат можно найти по формуле
Расстояние между двумя точками в декартовой системе координат можно найти по формуле d=√x^2+y^2 Напишите программу, которая найдет...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru