Вобороте участвуют монеты достоинством 1 рубль, 2 рубля, 5 рублей и 10 рублей. сколькими способами можно набрать сумму 66 рублей?
148
223
Ответы на вопрос:
Вариант понимания условия №1. мы достаём монеты по одной, и порядок монет важен (т.е., например, если мы вытащили сначала монету 1 рубль, потом 5 рублей и если сначала 5 рублей, потом 1 рубль - разные способы). обозначим c(n) - число способов набрать n рублей. очевидно, c(n) = c(n-1) + c(n-2) + c(n-5) + c(n-10) [представим себе. что мы знаем число способов набрать n-5 рублей. тогда если мы уверены, что последней вытащили 5-рублёвую монету, то способов будет c(n). финальный ответ - сумма по всем возможным выборам последней монеты] полагая c(n) = 0 при всех n < 0, c(0) = 1, получим по этой формуле с(66) = 1431020833989040 cчитать можно, например, такой программой: var c: array[-9..66] of biginteger; begin for var i : = -9 to -1 do c[i] : = 0; c[0] : = 1; for var i : = 1 to 66 do c[i] : = c[i - 1] + c[i - 2] + c[i - 5] + c[i - 10]; print(c[66]); end. вариант понимания условия №2 . нам порядок выдачи не важен. тогда вопрос по сути сводится к числу целых неотрицательных решений уравненияx + 2y + 5z + 10t = 66, где x, y, z, t - число 1-, 2-, 5- и 10-рублёвых монет соответственно. тут можно написать общую формулу, но она будет объемной, так что вычислять по ней совсем не радостно (даже с компьютером). поэтому проще все варианты перебрать. ответ получится 700. пример программы: begin var count : = 0; for var t : = 0 to 6 do for var z : = 0 to (66 - 10*t) div 5 do for var y : = 0 to (66 - 10*t - 5*z) div 2 do inc(count); print(count); end. подобным образом можно считать и вручную. по сути нам требуется вычислить сумму [1 + (66 - 10t - 5z)/2] по всем допустимым t, z ([x] - целая часть x). перебираем сначала t, потом z: t = 0. z = 0,1,. вклад в сумму 34 + 31 + 29 + 26 + 24 + 21 + 19 + 16 + 14 + 11 + 9 + 6 + 4 + 1 = 245. t = 1. z = 0,1,. легко понять, что здесь будут все числа без первых двух слагаемых: 29 + 26 + 24 + 21 + 19 + 16 + 14 + 11 + 9 + 6 + 4 + 1 = 245 - 34 - 31 = 180 аналогично, t = 2: 180 - 29 - 26 = 125 t = 3: 125 - 26 - 21 = 80 t = 4: 80 - 19 - 16 = 45 t = 5: 45 - 14 - 11 = 20 t = 6: 20 - 9 - 6 = 5 итого 245 + 180 + 125 + 80 + 45 + 20 + 5 = 700
1)изобретение фотографии 1826 год2) первая запись звука с фонографа 18773) демонстрация первого кинофильма 1895 год4)изобретение магнитофона 1929 год5) появление первых лазерных дисков 1980
Реши свою проблему, спроси otvet5GPT
-
Быстро
Мгновенный ответ на твой вопрос -
Точно
Бот обладает знаниями во всех сферах -
Бесплатно
Задай вопрос и получи ответ бесплатно
Популярно: Информатика
-
Feraaa210805.08.2022 00:37
-
салмик05.04.2021 02:50
-
missisleos21.11.2021 13:09
-
Leondjdkdbejxncus08.09.2022 15:45
-
Маргарита551507.01.2020 17:55
-
rahat917.04.2020 07:55
-
ИваПоля18.10.2022 18:18
-
elizabetfox122220.11.2022 01:14
-
Wow0116.06.2023 14:15
-
deisika727.11.2020 01:28
Есть вопросы?
-
Как otvet5GPT работает?
otvet5GPT использует большую языковую модель вместе с базой данных GPT для обеспечения высококачественных образовательных результатов. otvet5GPT действует как доступный академический ресурс вне класса. -
Сколько это стоит?
Проект находиться на стадии тестирования и все услуги бесплатны. -
Могу ли я использовать otvet5GPT в школе?
Конечно! Нейросеть может помочь вам делать конспекты лекций, придумывать идеи в классе и многое другое! -
В чем отличия от ChatGPT?
otvet5GPT черпает академические источники из собственной базы данных и предназначен специально для студентов. otvet5GPT также адаптируется к вашему стилю письма, предоставляя ряд образовательных инструментов, предназначенных для улучшения обучения.