1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
| RathaR |
1.01.2010 19:03
Сообщение
#1
|
![]() Знаток ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 346 Пол: Мужской Реальное имя: Иван Репутация: 7 |
Привет всем в Новом Году
Вспомнилась мне, задачка, которая фигурировала в цитате с баша, а именно: "Даны координаты начала и конца двух отрезков, определить пересекаються ли они". Вот я и задумался над этим... в голову пришел лишь один алгоритм: 1) У нас даны координаты 4 точек, запишем их в таком порядке, чтобы образовался полигон(для нахождения диагоналей). 2) Находим площадь этого полигона(половина произведения диагоналей на синус угла между ними). 3) Сравниваем полученый результат с половиной произведения наших отрезков на синус угла между ними. 4) Если площади совпали, значит отрезки являються диагоналями, а следовательно пересекаються, если нет, значит не перезекаються. Если какая либо из заданых точек принадлежит другому отрезку, это ведь ничего не меняет, всерамно должен работать. Длинну отрезков по координатам найдем легко, углы между отрезками можна найти через модуль разности углов под которым расположен каждый из отрезков к горизонтали. А сами углы находим через арктангенс в паскале. Следовательно при реализаии проблем возникнуть не должно... но мне интересно, как еще можно решить эту задачу(желательно по проще)? Визуально-графический метод не предлагать Сообщение отредактировано: RathaR - 1.01.2010 19:03 -------------------- Считающий себя единственым здравомыслящим человеком сумасшедший? Если да, возможно я псих...
Пусть умолкнет всякий критик! Я - системный аналитик! |
![]() ![]() |
| andriano |
2.01.2010 11:13
Сообщение
#2
|
|
Гуру ![]() ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 1 168 Пол: Мужской Реальное имя: Сергей Андрианов Репутация: 28 |
Сразу споткнулся на:
Цитата запишем их в таком порядке, чтобы образовался полигон А каков, собственно, критерий, что точки упорядочены нами именно в нужном порядке?Боюсь, на один шаг в алгоритме это никак не тянет. И чем, собственно, не устраивает наиболее очевидный алгоритм? 1. По координатам записываем уравнения прямых. 2. Решаем полученную систему уравнений, получая координаты точки пересечения прямых (если нет, значит, не пересекаются). 3. Узнаем, лежит ли точка пересечения внутри каждого из отрезков или вне его. |
| TarasBer |
5.01.2010 15:53
Сообщение
#3
|
![]() Злостный любитель ![]() ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 1 755 Пол: Мужской Репутация: 62 |
2. Решаем полученную систему уравнений, получая координаты точки пересечения прямых (если нет, значит, не пересекаются). Ага разбирая отдельно случай вертикальных отрезков, горизонтальных, нулевого определитеся системы. Это отвратительное решение в лоб. Как делал бы я. Задаём прямую, содержащую отрезок 1 в виде ax+by+c = 0. Подставляем в левую часть концы второго отрезка. Если получились числа одного знака - то не пересекаются. Если разного, то потом делаем то же самое, но наоборот - концы первого отрезка подставляем в уравнение для второго. Если опять разного знака - то пересекаются. Добавлено через 2 мин. Выглядело это примерно так:
На самом деле, это результат выкидывания всего лишнего из функции, считающей квадрат расстояния между двумя отрезками. Добавлено через 4 мин. И вижу я в той теме тот же ужас с разбором отдельного вертикального случая. Я вообще терпеть не могу анизотропные решения (то есть, зависящие от направления и выбора системы координат). Добавлено через 1 мин. А ещё надо разобрать случай, когда отрезки ПОЧТИ вертикальны (да, да, делить на ПОЧТИ ноль тоже запрещено), и ПОЧТИ параллельны. Короче, мой вариант лучше. И даже операция деления нигде не используется. -------------------- |
| sheka |
5.01.2010 18:17
Сообщение
#4
|
![]() Я. ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 809 Пол: Мужской Реальное имя: Саша Репутация: 11 |
Подставляем в левую часть концы второго отрезка. Если получились числа одного знака - то не пересекаются. Если разного, то потом делаем то же самое, но наоборот - концы первого отрезка подставляем в уравнение для второго. Если опять разного знака - то пересекаются. Класс! +1 Мне подобная идея сразу пришла в голову, только не получалось с реализацией, т.к. думал реализовать разницу знаков через вертикальную и горизонтальную прямые, которые бы проходили через одну из точек отрезка...А тут оказывается все намного проще) |
RathaR Пересекаються ли отрезки 1.01.2010 19:03
Lapp мне интересно, как еще можно решить эту задачу(жел... 1.01.2010 19:45
RathaR
Искал... не нашел ничего похожего...
Непонял... ... 2.01.2010 17:05
sheka 100пудово решал бы именно так, как предложил andri... 2.01.2010 18:30

RathaR
могу предложить извращенный вариант :lol: исполь... 3.01.2010 13:21
Lapp Искал... не нашел ничего похожего...Вах! )) От... 3.01.2010 22:44
RathaR
Вах! )) [url=http://forum.pascalnet.ru/index.... 3.01.2010 23:33
Lapp Недосмотрел, бывает :rolleyes: Хотя и не мудрено, ... 4.01.2010 3:38
andriano
Но там ведь реализован метод через уравнения прям... 4.01.2010 11:41
Unconnected
А как по координатам можно записать уравнение пр... 4.01.2010 22:10
RathaR
А как по координатам можно записать уравнение пря... 4.01.2010 22:18
Unconnected Ага, спасибо, википедия лучше гугла иногда) 4.01.2010 22:42
andriano
википедия лучше гугла
Это в перлы.
Нет, можно, к... 5.01.2010 11:32
RathaR
Это в перлы.
Да ладно, чего к словам то придират... 5.01.2010 14:23
TarasBer И название темы поправте, а то глаза режеть. 5.01.2010 17:20
Lapp И название темы поправте, а то глаза режет[color=#... 6.01.2010 0:00
andriano TarasBer, выразись, пожалуйста, конкретнее, какую ... 6.01.2010 0:03
Lapp Прежде, чем выделять красным предполагаемую ошибку... 6.01.2010 1:01
RathaR
внимательно перечитал название темы.
эм... я в н... 6.01.2010 2:38
Lapp стараюсь как могу,Именно так. И это главное.
Я, в... 6.01.2010 3:00
TarasBer > а по сабжу "пересекаються" поправля... 6.01.2010 13:36
Lapp А в украинском разве нет правил тся-ться? Впрочем,... 7.01.2010 1:40
TarasBer
Вот вы опять всё приняли на свой счёт. Хотя у мен... 7.01.2010 14:47
Lapp Вот и хорошо )) 7.01.2010 23:27
sheka То же самое, но чуть больше слов :)
http://users.l... 13.08.2012 16:48![]() ![]() |
|
Текстовая версия | 14.12.2025 17:29 |