1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
| Zxzc |
6.05.2006 22:33
Сообщение
#1
|
|
Пионер ![]() ![]() Группа: Пользователи Сообщений: 58 Пол: Мужской Реальное имя: Максим Репутация: 0 |
Помогите решить задачу:
Мальчик накапливал в копилке деньги. Однажды он увидел в магазине некий товар стоимостью S. Дело в том что копилка заполнена не до конца, а разбивать ее можно лишь при 100% уверенности, что количества денег будет достаточно. Но он не помнит сколько монет какого достоинства клал в копилку. Также известна масса пустой копилки и, конечно, текущая масса. Известны соотношения Номинал <--> Масса монеты. Нужно определить минимальную вероятность и если она равна 100% вывести:"Вперед!!!!!!!!!!!" Я решил задачу, получилось что количество вложенных циклов равно количеству разновидностей монет. Проблема в том, что заранее не известно число разновидностей монет. Препод предложил идти через двумерный массив(M,N его - большие числа). И каким-то замысловатым способом из 2-х массивов(в первом - номиналы, во втором - массы) получаем массив [m,n]-й элемент к-рого - минимальное кол-во денег... Потом он сам запутался... Мда.. Сообщение отредактировано: Zxzc - 13.05.2006 21:44 |
![]() ![]() |
| Zxzc |
9.05.2006 10:31
Сообщение
#2
|
|
Пионер ![]() ![]() Группа: Пользователи Сообщений: 58 Пол: Мужской Реальное имя: Максим Репутация: 0 |
Цитата монет с этим миниальным удельным достоинством нельзя набрать целое количество так чтобы они полностью покрыли массу монет в копилке А нам это надо? Удельное достоинство изначально подразумевает не целые числа. Мы ищем не минимальное количество медяшек, а их сумму! Или я не прав? А! Я наконец-то понял суть проблемы. Раньше я трактовал ее несколько иначе! Сообщение отредактировано: Zxzc - 9.05.2006 16:16 |
| Lapp |
10.05.2006 4:18
Сообщение
#3
|
![]() Уникум ![]() ![]() ![]() ![]() ![]() ![]() ![]() Группа: Модераторы Сообщений: 6 823 Пол: Мужской Реальное имя: Лопáрь (Андрей) Репутация: 159 |
А! Я наконец-то понял суть проблемы. Раньше я трактовал ее несколько иначе! Сейчас я перечитал свой пост - не очень-то ясно написано.. Общий вес монет задается константой S. Набор монет задается в типизированной константе Coins. В каждой записи указываются номинал монеты (v, от слова value) и вес (w, от слова weight). Число записей (число различных типов монет) задается константой M (в моем примере 6 разичных монет достоинством 1, 2, 5, 10, 20 и 50 единиц (копеек Если невозможно подобрать комбинацию монет с заданным весом S, то программа выдает фразу "No match found" (совпадение не найдено). Если найдена искомая комбинация монет (согласно логике поиска, она обязательно минимальная [см. P.S.]), то выводится соответствующая сумма в единцах (копейках). Я думаю, было бы полезно выводить и способ, которым набрана данная сумма. Для этого нужно добавить одну строчку, что я сейчас и сделаю... [в течение некоторого времени ожесточенно колотит по клаве, чешет репу и наливает чай] ...сделал! В результате получилась фактически новая версия Кроме прочего, старая версия странным образом глючила.. Я так и не смог разобраться, в чем дело, поскольку после добавления определенных переменных и операторов для отладки она глючить перестала, вроде. Если кто-то заметит глюки, прошу сказать мне о них. Еще добавлю, что результаты (зависимость минимально возможной суммы от веса) выглядят довольно забавно Распределение монет по весам я взял чисто от балды, оно не имеет к обычной реальности никакого отношения (думаю, это и не требовалось). Рекомендую поиграться с ним, чтобы понять суть проблемы.. И последнее: хочу обратить внимание на пользу рекурсии. Фактически, все решение укладывается в функцию MinFill. Все остальное - подготовка ряда значений и весов монет. Если принять, что он уже упорядоченный и без лишних значений - прога уменьшится драматически Итак, вот новая версия. Кстати, она запрашивает вес монет с клавиатуры..
P.S. Моя фраза об обязательной минимальности резульата на самом деле нуждается в доказательстве. Я уверен в этом довольно сильно, но руку на отсечение пока не дам... Кто это докажет/опровергнет? -------------------- я - ветер, я северный холодный ветер
я час расставанья, я год возвращенья домой |
Zxzc Задача о вероятности 6.05.2006 22:33
volvo Я решил задачу, получилось что количество вложенны... 6.05.2006 23:06
Zxzc :no1: , рекурсия не причем.
Вот моё, абсолютно не ... 7.05.2006 22:51
volvo :no1: , рекурсия не причем.
Уверен? Я - нет... Смо... 7.05.2006 23:39
мисс_граффити
2. Если бы меньшей монете соответствовал меньший... 8.05.2006 9:23
zZz а не судьба определить удельное достоинство каждой... 8.05.2006 10:25
Zxzc volvo, MaxAvail в моем решении найден не верно. Го... 8.05.2006 21:28
zZz одно маленькое дополнение: может получиться так чт... 8.05.2006 21:53
Zxzc
Да вся эта задача сплошная неприятность!... 8.05.2006 22:23
zZz предлагаю найти число монет мин удельного достоинс... 8.05.2006 22:50
Zxzc :blink: !!!!!!!!... 8.05.2006 22:51
zZz по-моему это все то нахождение монеты с наименьшей... 8.05.2006 23:25
lapp Заинтересовала меня эта задачка тоже.. Мужики, вы... 9.05.2006 14:52
Zxzc Я понял ход твоих мыслей! :yes2: Т.е. если не... 12.05.2006 6:28
lapp > Я понял ход твоих мыслей! :yes2:
> Т... 12.05.2006 6:42
Zxzc Я сейчас готовлюсь к экзаменам и у меня даже нет в... 12.05.2006 21:52
Zxzc Внимание! Я достал-таки исходники!
1:
con... 13.05.2006 12:10
lapp
Внимание! Я достал-таки исходники!
Перво... 13.05.2006 14:12
Zxzc :yahoo!: Вы-ход-ной! Наконец-то провел все... 13.05.2006 21:41![]() ![]() |
|
Текстовая версия | 2.11.2025 9:37 |