|
28 / 27 / 11
Регистрация: 12.03.2009
Сообщений: 85
|
|
Лесенка - динамическое программирование19.08.2009, 09:48. Показов 30936. Ответов 51
Метки нет (Все метки)
Здраствуйте. У меня есть одна классическая задачка про Лесенку.
Лесенка Лесенкой называется набор кубиков, в котором каждый более верхний слой содержит кубиков меньше, чем предыдущий. Требуется написать программу, вычисляющую число лесенок, которое можно построить из N кубиков. Входные данные Во входном файле INPUT.TXT записано натуральное число N (1 ≤ N ≤ 100) – количество кубиков в лесенке. Выходные данные В выходной файл OUTPUT.TXT необходимо вывести число лесенок, которые можно построить из N кубиков. Примеры INPUT.TXT OUTPUT.TXT 3 2 6 4 Я решил эту задачку с помощью грубого перебора и проходит тесты. Но я слышал что есть и другое эффективное решение с помощью динамическое программирование. Помогите решить.
0
|
|
| 19.08.2009, 09:48 | |
|
Ответы с готовыми решениями:
51
Динамическое программирование Динамическое программирование
|
|
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
|
|||
| 19.08.2009, 19:21 | |||
И по условию не очень понял - приведи все варианты лесенок которые собственно нужно посчитать.
0
|
|||
|
640KB мне хватило на всё.
119 / 50 / 3
Регистрация: 07.06.2009
Сообщений: 442
|
|
| 19.08.2009, 19:32 | |
|
Минимальное число кубиков в лесенке - 3. Следовательно Число_Лесенок=Число_Кубиков\3
![]() Надо задачу уточнить. А про "динамическое программирование", переспросите того, кто это вам сказа - шо он имел ввиду под данным термином.
0
|
|
|
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
|
||
| 19.08.2009, 19:40 | ||
0
|
||
|
640KB мне хватило на всё.
119 / 50 / 3
Регистрация: 07.06.2009
Сообщений: 442
|
||
| 19.08.2009, 19:57 | ||
|
Я определял лесенку, как множество ступенек, для каждой из которых кроме первой, есть предыдущая, для непоследней - есть последующая.
0
|
||
|
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
|
||||
| 19.08.2009, 20:06 | ||||
Скорее всего лесенка из одного слоя - нормальное явление, просто предельный случай в математике.
А то мы тут скоро станем гуру в лесенках и без автора
0
|
||||
|
Почетный модератор
64314 / 47610 / 32743
Регистрация: 18.05.2008
Сообщений: 115,168
|
|
| 19.08.2009, 20:13 | |
|
Условие задачи.
http://informatics.mccme.ru/mo... pterid=211
0
|
|
|
640KB мне хватило на всё.
119 / 50 / 3
Регистрация: 07.06.2009
Сообщений: 442
|
|
| 19.08.2009, 20:49 | |
|
Блин, опять лесенка не по ГОСТу.
Там точно и не сказано про лесенку из 1 слоя! Но там сказано "сколько различных". Тут опять хрень - сколько вариантов существует, или сколько можно построить одновременно разных лесенок из заданного числа кубиков? odip, тогда Вы, дайте пожалуйста ссылку на "динамическое программирование", только применимое к таким языкам как Паскакаль или Си ![]() Видимо, было не "динамическое программирование", а алгоритмы с использованием "динамических структурх данных". Но использование "динамических структур", один хрен, суть алгоритма не изменит, всё равно, если не математические формулы с факториалами, то остаётся поиск тупым перебором вариантов. +1 Там наверно имелось ввиду, что разные лесенки, но содержащие ровно N кубиков. Плюс есть подсказка - загнать всё в матрицу (лучше в вектор с целыми числами), после этого заниматься перегонкой единиц из одной ячейки в другие, при наличии возможности.
0
|
|
|
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
|
|||
| 19.08.2009, 20:59 | |||
|
Из 3 кубиков можно построить 2 лесенки.
Я так понимаю: 3 кубика в один этаж, 2 кубика и 1 кубик сверху. Отсюда следует что 1 кубик, тоже лесенка. Из 6 кубиков можно построить 4 лесенки. 6; 5,1; 4,2; 3,2,1;
Добавлено через 1 минуту 18 секунд
0
|
|||
|
3920 / 921 / 125
Регистрация: 16.04.2009
Сообщений: 1,956
|
||||||
| 19.08.2009, 21:30 | ||||||
|
Я думаю решается рекурсией: берем все кубики и выкладываем в 1 слой (это раз), далее берем 1 кубик и кладем на верх (это два). А суть рекурсии в том что когда мы будем "отбирать" от первого ряда больше кубиков то мы не будем учитывать первый ряд а просто представим что из взятого надо построить опять же лесенку. Алгоритм похож на фибоначчи.
![]() Но мне кажется 80% кода правильное.
2
|
||||||
|
640KB мне хватило на всё.
119 / 50 / 3
Регистрация: 07.06.2009
Сообщений: 442
|
||
| 19.08.2009, 21:46 | ||
|
Поправка к закону Мерфи - Мерфи был ба-а-альшим оптимистом
0
|
||
|
3920 / 921 / 125
Регистрация: 16.04.2009
Сообщений: 1,956
|
|
| 19.08.2009, 22:05 | |
|
Не по теме: Закон главбуха: если баланс не сошелся - значит в балансе ошибка, если сошелся - ошибок как минимум две. ![]() Я и так 20% (целых 2 строки) отвел под ошибки, куда уж больше.
0
|
|
|
Почетный модератор
64314 / 47610 / 32743
Регистрация: 18.05.2008
Сообщений: 115,168
|
||
| 20.08.2009, 07:46 | ||
0
|
||
|
28 / 27 / 11
Регистрация: 12.03.2009
Сообщений: 85
|
||||||
| 20.08.2009, 09:30 [ТС] | ||||||
|
Я вот так решил:
0
|
||||||
|
3920 / 921 / 125
Регистрация: 16.04.2009
Сообщений: 1,956
|
|
| 20.08.2009, 11:27 | |
|
0
|
|
|
Почетный модератор
64314 / 47610 / 32743
Регистрация: 18.05.2008
Сообщений: 115,168
|
||
| 20.08.2009, 11:50 | ||
0
|
||
|
3920 / 921 / 125
Регистрация: 16.04.2009
Сообщений: 1,956
|
||||||
| 20.08.2009, 11:57 | ||||||
Добавлено через 57 секунд подозреваю что тут: (k - 1) \ 2 Добавлено через 5 минут 20 секунд Точно, так и есть. Понял в чем ошибка! Код считает что если первый ряд например из 5 кубиков то на него нельзя положить больше 4, хотя можно аж 6 (3-2-1).
1
|
||||||
|
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
|
|
| 20.08.2009, 22:30 | |
|
Я думаю делать нужно рекурсивный спуск, но ответы запоминать в кэше.
Например если мы знаем что их трех кубиков можно сложить две лесенки, то это достаточно вычислить один раз, а далее везде где потребуется будем просто брать из кэша.
0
|
|
|
3920 / 921 / 125
Регистрация: 16.04.2009
Сообщений: 1,956
|
||||||
| 21.08.2009, 12:52 | ||||||
|
на мой взгляд я подошел к решению, но пока где-то ошибка (а куда же без них).
Max = IIf(Max = Int(Max), Int(Max), Int(Max) + 1) это можно убрать заменив на округление вверх вот этого: Sqr(2 * k + 0.25) - 0.5 Добавлено через 1 минуту 0 секунд откуда эти непонятные цифры объясню позже
0
|
||||||
|
сишник
130 / 36 / 1
Регистрация: 25.07.2009
Сообщений: 291
|
||||||
| 21.08.2009, 14:06 | ||||||
|
Зачем все так усложнять?
0
|
||||||
| 21.08.2009, 14:06 | |
|
Помогаю со студенческими работами здесь
20
Динамическое программирование Динамическое программирование Динамическое программирование задача динамическое программирование Динамическое программирование - задача Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования.
Часть библиотеки BedvitCOM
Использованы. . .
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога
SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога
SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
|
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
|
|
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога
SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
|
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога
Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip"
Извлеките архив и вы увидите. . .
|
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога
Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д.
Сборка примера
Скачайте. . .
|
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|