Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/32: Рейтинг темы: голосов - 32, средняя оценка - 4.94
1 / 1 / 0
Регистрация: 01.09.2012
Сообщений: 30

Подсчет количества способов, которыми можно разменять рубль медными монетами (достоинством 1, 2, 3, 5 копеек)

07.09.2012, 16:08. Показов 6836. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
составить алгоритм подсчета количества способов, которыми можно разменять рубль медными монетами(достоинством в1,2,3,5 копеек)
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.09.2012, 16:08
Ответы с готовыми решениями:

Можно ли разменять 25 рублей десятью монетами достоинством в 1,2 и 5 рублей
Можно ли разменять 25 рублей десятью монетами достоинством в 1,2 и 5 рублей.Если <<Да>>, то указать количество каждой из монет....

Сколькими способами можно отобрать команду в составе 5 человек из 8 кандидатов;из 10 кандидатов; из 11 кандидатов? Подсчет количества способов отбора
Нужна помощь, есть код на Pascal нужно в C. Вот программа: function fact(x: longint): longint; begin if x=0 then fact:=1 ...

Алгоритм подсчета количества способов, которыми можно разменять рубль медными монетами
Составить алгоритм подсчета количества способов, которыми можно разменять рубль медными монетами(достоинством 1, 2, 3, 5 копеек)

7
Day
 Аватар для Day
1180 / 990 / 83
Регистрация: 29.10.2009
Сообщений: 1,385
07.09.2012, 16:35
Цитата Сообщение от алишка999 Посмотреть сообщение
разменять рубль медными монетами(достоинством в1,2,3,5 копеек)
Видать, задачка-то еще со времен СССР
0
1 / 1 / 0
Регистрация: 01.09.2012
Сообщений: 30
07.09.2012, 16:36  [ТС]
а что делать раз задали
0
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
07.09.2012, 21:39
Цитата Сообщение от алишка999 Посмотреть сообщение
а что делать раз задали
Используйте рекурсивную функцию
F(n) = F(n-1) + F(n-2) + F(n-3) + F(n-5)
с начальными условиями
F(0) = 1,
F(x) = 0 при x < 0

получается 117372865913707249 способов. обычной рекурсией его не получить. Только с сохранением уже подсчитанного.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include<iostream>
const long N = 101;
 
long long F(long n)
{
   static long long count[N];
   if (n < 0)
      return 0;
   else if (count[n] != 0)
      return count[n];
   else if (n == 0)
      return (count[n] = 1);
   else
      return (count[n] = F(n-1) + F(n-2) + F(n-3) + F(n-5));
}
 
int main()
{
   std::cout << F(100);
   return 0;
}
1
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
08.09.2012, 02:26
Лучший ответ Сообщение было отмечено как решение

Решение

Цитата Сообщение от Thinker Посмотреть сообщение
получается 117372865913707249 способов.
многовато )
У меня получается всего 6518.
Все дело в том что например варианты для набора 3-х копеек: (1 2) и (2 1) Вы считаете разными, хотя это одно и тоже.
3
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
08.09.2012, 12:34
Да, действительно, я учел порядок, а он не важен, спасибо. Так задачу о наклейке марок надо решать, тут другая рекурсия
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include<iostream>
 
long F(long *a, long i, long n)
{
   if (n < 0)
      return 0;
   else if (n == 0)
      return 1;
   return i < 0 ? 0 : F(a, i - 1, n) + F(a, i, n - a[i]);
}
 
int main()
{
   long a[4] = {1, 2, 3, 5};
   std::cout << F(a, 3, 100);
   return 0;
}
Ответ: 6518. Здесь последовательности упорядочены.
При этом существует 117372865913707249 способов наклеить марки на конверт стоимостью в 1,2,3 и 5 коп., чтобы в сумме получился 1 руб, так как последовательности неупорядочены.
1
0 / 0 / 0
Регистрация: 04.04.2013
Сообщений: 16
09.07.2013, 14:59
Цитата Сообщение от Thinker Посмотреть сообщение
Да, действительно, я учел порядок, а он не важен, спасибо. Так задачу о наклейке марок надо решать, тут другая рекурсия
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include<iostream>
 
long F(long *a, long i, long n)
{
   if (n < 0)
      return 0;
   else if (n == 0)
      return 1;
   return i < 0 ? 0 : F(a, i - 1, n) + F(a, i, n - a[i]);
}
 
int main()
{
   long a[4] = {1, 2, 3, 5};
   std::cout << F(a, 3, 100);
   return 0;
}
Ответ: 6518. Здесь последовательности упорядочены.
При этом существует 117372865913707249 способов наклеить марки на конверт стоимостью в 1,2,3 и 5 коп., чтобы в сумме получился 1 руб, так как последовательности неупорядочены.
Цитата Сообщение от Thinker Посмотреть сообщение
int main()
{
* *long a[4] = {1, 2, 3, 5};
* *std::cout << F(a, 3, 100);
* *return 0;
}
Почему у вас в функции F, вторая переменная равна 3?
0
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
09.07.2013, 15:02
Цитата Сообщение от Dantes48 Посмотреть сообщение
Почему у вас в функции F, вторая переменная равна 3?
это индекс последнего элемента массива a
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
09.07.2013, 15:02
Помогаю со студенческими работами здесь

Сколькими способами можно разменять 10 копеек монетами по 1, 2, 3 и 5 копеек?
Помогите решить задачу пожалуйста &quot;сколькими способами можно разменять 10 копеек монетами по 1 2 3 и 5 копеек при условии что каждая из...

Определить, можно ли разменять сумму в N копеек данными монетами
Задача 12. Имеются монеты достоинством 10,15,20,50 копеек. Определить, можно ли разменять сумму в N копеек данными монетами.

Рекурсивно определить, мржно ли заданную сумму денег разменять монетами по 3, 10, 15 копеек
Добрый день. Подскажите, пожалуйста, где ошибка в решении следующей задачи: написать программу, которая рекурсивно позволяет определить,...

Найдите число способов наклейки марок достоинством в 3, 5 и 10 копеек так, чтобы общая сумма была равна 16 коп
Найдите число способов наклейки марок достоинством в 3, 5 и 10 копеек так, чтобы общая сумма была равна 16 копейкам.

Можно ли разменять 25 рублей десятью купюрами достоинством в 1,3,5
можно ли разменять 25 рублей при помощи десяти купюр достоинством в 1,3,5 паскальABC


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru