Форум программистов, компьютерный форум CyberForum.ru

Найти минимальное количество купюр, которое необходимо использовать, чтобы выдать сумму в n гривен - C++

Восстановить пароль Регистрация
 
JLevenets
 Аватар для JLevenets
0 / 0 / 0
Регистрация: 23.11.2013
Сообщений: 14
09.04.2014, 23:07     Найти минимальное количество купюр, которое необходимо использовать, чтобы выдать сумму в n гривен #1
В банкомате имеются в достаточном количестве купюры номиналом 10, 20, 50, 100, 200 и 500 гривен. Найти минимальное количество купюр, которое необходимо использовать, чтобы выдать сумму в n гривен или вывести -1, если указанную сумму выдать нельзя.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.04.2014, 23:07     Найти минимальное количество купюр, которое необходимо использовать, чтобы выдать сумму в n гривен
Посмотрите здесь:

C++ Наименьшее количество купюр, которыми можно выдать n гривен
Минимальное количество байт, которое займёт отрицательное число C++
Какое минимальное число букв необходимо заменить в слове Х, с тем, чтобы оно стало перевертышем? C++
6. Написать программу, которая предлагает пользователю ввести сумму в гривнах (дробное число) и выводит по отдельности количество гривен и количество C++
Выдать N рублей минимальным набором купюр C++
Найти минимальное количество купюр для оплаты суммы C++
Найти минимальное количество шариков, которое необходимо перекрасить, чтобы все шарики были одного цвета C++
C++ Найти минимальное время, за которое можно поджарить все котлеты

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
prosto_lynx
 Аватар для prosto_lynx
49 / 24 / 1
Регистрация: 09.06.2008
Сообщений: 225
09.04.2014, 23:44     Найти минимальное количество купюр, которое необходимо использовать, чтобы выдать сумму в n гривен #2
Вычитаете из суммы (которую нужно набрать) максимально возможный номинал (из всех купюр). При каждом вычитании увеличиваете значение счетчика на 1.
Данные действия повторяются, пока сумма не станет равной 0 либо невозможно будет вычесть минимальный номинал купюр. (причем, если нельзя вычесть минимальный номинал купюр, то, соответственно, присвоить счетчику значение "-1").
IGPIGP
Комп_Оратор)
 Аватар для IGPIGP
6166 / 2895 / 282
Регистрация: 04.12.2011
Сообщений: 7,696
Записей в блоге: 3
10.04.2014, 00:16     Найти минимальное количество купюр, которое необходимо использовать, чтобы выдать сумму в n гривен #3
А вот фантазия на тему фундаментального алгоритма теории традиционно ориентированных графов...
(смотрите не скажите, что-то подобное преподавателю!!!)
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#include <iostream>
using namespace std;
int main(){
    int bank_notes[] = { 10, 20, 50, 100, 200, 500 };
    int sum_to_pay;
    cout<<"Enter the summ to pay: ";
    cin>>sum_to_pay;
cout<<endl;
const int sz_of_banknotes = sizeof(bank_notes)/sizeof(bank_notes[0]);
int bank_notes_number[sz_of_banknotes] = {0};
int cnt=0;
for(int i = sz_of_banknotes - 1; i >= 0; --i){  
bank_notes_number[cnt++]=sum_to_pay/bank_notes[i];
sum_to_pay -= bank_notes_number[cnt-1]*bank_notes[i];
}
cnt=0;
for(size_t i = 0; i < sz_of_banknotes; ++i){
    if(bank_notes_number[i]){
cout<<"Nominal with "<<bank_notes[sz_of_banknotes - 1 - i]<<" wil be "<<bank_notes_number[i]<<endl;
cnt++;
    }
}
if(!cnt)cout<<"-1";
    cout<<endl;
system("pause"); 
    return 0; 
}
Yandex
Объявления
10.04.2014, 00:16     Найти минимальное количество купюр, которое необходимо использовать, чтобы выдать сумму в n гривен
Ответ Создать тему
Опции темы

Текущее время: 13:10. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru