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

Ну очень интересная задача!

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





СообщениеДобавлено: Чт Дек 09 2004 20:40    Заголовок сообщения: Ну очень интересная задача! Ответить с цитатой

Помогите решить задачку!

Найти количество покрытий прямоугольника 2*n(1<=n<=1000) фигурками в виде дощечок, каждая из которых представляеть собой 1*1, или 2*1, или уголок из трех квадратов 1*1.Фигурки должны заполнить прямоугольник без промежутков.
Вернуться к началу
DmitryShm



Зарегистрирован: 17.11.2003
Сообщения: 211
Откуда: Казань

СообщениеДобавлено: Пт Дек 10 2004 09:15    Заголовок сообщения: простая задача Ответить с цитатой

Введи A(n) - число способов для доски вида 2.2.2..2.1 , B(n) - число способов для доски вида 2.2.2.2..2 . Ясно, что если доску перевернуть, то пустота над 1 всегда может быть сверху. На данное место всегда можно поставить 3 разные фигуры, понятно из условия. Для доски данной длины пробуем выразить кол-во способов через простые рекуррентности от A и B, понятно. Итак,
A(n) = B(n-1) + B(n-2), B(n) = A(n) + B(n-1) + A(n-1).

По-моему должно быть так.

Т.е. совет таков: если надо решить прям сейчас, то заводи 2 массива и за 1 проход решай. Если надо решить в замкнутой форме, т.е. получить решение в виде формулы B(n) = L(1,n,n^2), то используй производящие функции для получения формулы. Сейчас не хочу этого делать, т.к. мало времени.

Прочитай про динамическое программирование, чтобы научиться решать подобные задачки, ну и прочитай про производящие функции, чтобы получать формулы.
_________________
love IT
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail
X-Ray
Гость





СообщениеДобавлено: Сб Дек 11 2004 18:22    Заголовок сообщения: Ответить с цитатой

Я тут подумал! Напиши пожайлуста, если не трудно, где можно прочитать про динамическое программирование, чтобы научиться решать подобные задачки и про производящие функции, чтобы получать формулы.
Вернуться к началу
Гость






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

Окуловские книжки подойдут: Окулов С. М. "Информатика в задачах", Пестов, Окулов "100 задач по информатике" -- это для школьников, а для более продвинутых Д. Кнут подойдет.
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: 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
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...