![]() |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
![]() ![]() |
![]() |
Feagor |
![]()
Сообщение
#1
|
![]() ыыыыщщщщщщыыыы ![]() ![]() Группа: Пользователи Сообщений: 68 Пол: Мужской Реальное имя: Иван Репутация: ![]() ![]() ![]() |
Условие:
даны действительные числа x1,y1,x2,y2,...xn,yn известно что точки p1,p2,...pn с коорданатами (x1,y1),(x2,y2),...(xn,yn) попарно различны. Найти выпуклый многоугольник с вершинами в некоторых из точек p1,p2,..pn, который содержит все точки p1,p2,...pn. Многоугольник должен быть предоставлен последовательностью вершин. ваще хз как делать, листинг, то что понял как делать ![]() uses crt; Прошу помощи, завтра сдавать... ![]() Сообщение отредактировано: Feagor - 24.12.2007 21:07 -------------------- Никогда не задавайте вопрос, если не уверены, что хотите получить ответ...
|
volvo |
![]()
Сообщение
#2
|
Гость ![]() |
Только при чем здесь сортировка массива - непонятно. Это, вообще говоря, называется Задача построения выпуклой оболочки
Добавлено через 6 мин. Вообще-то это была ссылка, если что ![]() |
Feagor |
![]()
Сообщение
#3
|
![]() ыыыыщщщщщщыыыы ![]() ![]() Группа: Пользователи Сообщений: 68 Пол: Мужской Реальное имя: Иван Репутация: ![]() ![]() ![]() |
ну я понял, спасибо, хоть появились мысли как делать
![]() Добавлено через 12 мин. еще подскажите можно как-нить найти угол через 3 точки, не использую длины сторон -------------------- Никогда не задавайте вопрос, если не уверены, что хотите получить ответ...
|
Michael_Rybak |
![]()
Сообщение
#4
|
Michael_Rybak ![]() ![]() ![]() ![]() ![]() Группа: Модераторы Сообщений: 1 046 Пол: Мужской Реальное имя: Michael_Rybak Репутация: ![]() ![]() ![]() |
можно арктангенсы углов посчитать. для точек А, В, С - проводим горизонтальный луч AD вправо, и считаем углы BAD и CAD через арктангенс. а потом отнимаем. и аккуратно все случаи расположения точек В и С относительно А нужно рассмотреть, чтобы угол получался от 0 до 180.
|
Feagor |
![]()
Сообщение
#5
|
![]() ыыыыщщщщщщыыыы ![]() ![]() Группа: Пользователи Сообщений: 68 Пол: Мужской Реальное имя: Иван Репутация: ![]() ![]() ![]() |
2 Michael_Rybak не это уже изврещение.
![]() -------------------- Никогда не задавайте вопрос, если не уверены, что хотите получить ответ...
|
Feagor |
![]()
Сообщение
#6
|
![]() ыыыыщщщщщщыыыы ![]() ![]() Группа: Пользователи Сообщений: 68 Пол: Мужской Реальное имя: Иван Репутация: ![]() ![]() ![]() |
такс....код немного увеличился по идее должен работать, но не работает....по идее работать должен через алгоритм Gift Wrapping. Прошу помощи.
Сообщение отредактировано: Feagor - 25.12.2007 11:44 -------------------- Никогда не задавайте вопрос, если не уверены, что хотите получить ответ...
|
volvo |
![]()
Сообщение
#7
|
Гость ![]() |
Ну, не сработал код на моих данных по самой прозаической причине: деление на 0 в строке:
cosx:=(l1*l1+l2*l2-l3*l3)/(2*l1*l2); Вот этот код работает по тому же алгоритму, но отрабатывает вполне успешно: Построение выпуклой оболочки множества |
Feagor |
![]()
Сообщение
#8
|
![]() ыыыыщщщщщщыыыы ![]() ![]() Группа: Пользователи Сообщений: 68 Пол: Мужской Реальное имя: Иван Репутация: ![]() ![]() ![]() |
2 volvo спасибо конечно за рабочий код, но хотелось бы не тупо чужой код перерисовать, а найти ошибку в своем, не понимаю почему получается деление на ноль...
-------------------- Никогда не задавайте вопрос, если не уверены, что хотите получить ответ...
|
volvo |
![]()
Сообщение
#9
|
Гость ![]() |
Цитата но хотелось бы не тупо чужой код перерисовать, а найти ошибку в своем Тогда начинай все с самого начала: твоя программа (вернее, ты, а не программа) ошибается уже на этапеЦитата Находим нижнюю-правую точку У тебя точка находится неверно... А все почему? Потому, что ты с какой-то стати проверяешь отдельно координаты X и Y, а надо было сделать что-то типа:x1[1] := x[1]; y1[1] := y[1]; Вот тогда будет действительно вычисляться нижняя-правая точка... А у тебя вычислялось вообще непонятно что. |
Feagor |
![]()
Сообщение
#10
|
![]() ыыыыщщщщщщыыыы ![]() ![]() Группа: Пользователи Сообщений: 68 Пол: Мужской Реальное имя: Иван Репутация: ![]() ![]() ![]() |
урряяяя, с божьей помощи кажись заработала, терь просьба протестить, и поправить, если где-то ошибки...
Добавлено через 3 мин. 2 volvo насчет точки сам нашел ошибку ![]() -------------------- Никогда не задавайте вопрос, если не уверены, что хотите получить ответ...
|
volvo |
![]()
Сообщение
#11
|
Гость ![]() |
Цитата просьба протестить Потестил. Неправильный результат выдает на тестовых последовательностях:const armax=8;Чтобы поправить, пришлось сделать так: Вот теперь этот тест проходит... Надо еще на нескольких проверить, чтобы быть уверенным что это работает правильно... Тестируй дальше ![]() |
Feagor |
![]()
Сообщение
#12
|
![]() ыыыыщщщщщщыыыы ![]() ![]() Группа: Пользователи Сообщений: 68 Пол: Мужской Реальное имя: Иван Репутация: ![]() ![]() ![]() |
2 volvo спасибо за помощь!!!! Все работает прекрасно единственно модно добавить условие, что при поиске следующей точки, если несколько углов имеют одинаковый угол, являющийся максимальным, брать ту до которой расстояние больше...ысчо раз спасибо, считаю что тема себя исчерпала, и её можно закрыть, рабочий код:
uses crt; -------------------- Никогда не задавайте вопрос, если не уверены, что хотите получить ответ...
|
![]() ![]() |
![]() |
Текстовая версия | 20.07.2025 6:30 |