Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Есть геометрическая задачка. Может, кто подскажет алгоритм..

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование
Предыдущая тема :: Следующая тема  
Автор Сообщение
--= Eagle =--



Зарегистрирован: 23.03.2004
Сообщения: 977
Откуда: Украина, Житомир

СообщениеДобавлено: Вт Июн 15 2004 12:57    Заголовок сообщения: Есть геометрическая задачка. Может, кто подскажет алгоритм.. Ответить с цитатой

Дан массив прямоугольников, нужно расположить их в форме прямоугольника с наименьшими возможными сторонами. Будет реализовно на Делфе. Нужен просто алгоритм. Rolling Eyes
_________________
Информация должна быть общедоступной!
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail Посетить сайт автора
Andy_user



Зарегистрирован: 03.12.2003
Сообщения: 382
Откуда: Санкт-Петербург

СообщениеДобавлено: Вт Июн 15 2004 14:19    Заголовок сообщения: Ответить с цитатой

Неясны условия:
1. Как задан массив прямоугольников;
2. Разрешается ли прямоугольники поворачивать на 90 градусов;
3. Уточните критерий оптимальности. Может быть наименьший периметр охватывающего примоугольника ?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
GREA



Зарегистрирован: 14.05.2003
Сообщения: 758
Откуда: Новосибирск

СообщениеДобавлено: Вт Июн 15 2004 14:45    Заголовок сообщения: Ответить с цитатой

Очевидно, начинать нужно с квадрата.
Его сторона - корень из суммы площадей.
Сначала пытаемся сложить одну сторону, к ней добавляем другой слой. Все рекурсивно. Если построение не удачно, должны собрать прямоугольник с наименьшей стороной (которая все-таки должа быть больше, чем на предыдущем шаге).
Повторяем процесс, пока не достигнем некого прямоугольника, который и будет минимальным.
Это самый базовый алгоритм.
Задача упрощается, если это похоже на пентамино (то есть, у всех длин сторон всех прямоугольников есть общий НОД)
Действительно, уточни условия и ограничения. Тогда можно будет обьяснить более понятно.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
--= Eagle =--



Зарегистрирован: 23.03.2004
Сообщения: 977
Откуда: Украина, Житомир

СообщениеДобавлено: Вт Июн 15 2004 14:46    Заголовок сообщения: Ща, в аську автору вопроса постучусь ;) Ответить с цитатой

Уже уточнил...

1. Масив ректанглов, кол-во и размер задаёт пользователь
2. Конечно, поворачивать можно
3. Да, наименьший периметр охватывающего прямоугольника

2 GREA

А кто сказал, что там будет хоть 1 квадрат?
_________________
Информация должна быть общедоступной!
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail Посетить сайт автора
GREA



Зарегистрирован: 14.05.2003
Сообщения: 758
Откуда: Новосибирск

СообщениеДобавлено: Вт Июн 15 2004 19:40    Заголовок сообщения: Ответить с цитатой

Я имел в виду то, что сначала, мы должны собирать прямоугольники в один большой КВАДРАТ (пытаемся минимизировать периметр). Если попытка не прошла, ищем суммарный прямоугольник максимально близкий к квадрату (минимальное увеличение одной из сторон). Решаем аналогичную задачу. В случае неудачи, опять увеличиваем сторону и повторяем процесс. Как только смогли собрать прямоугольник, он и будет минимальным (по периметру)
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...