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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.60
Belfegor
Ghost
172 / 172 / 6
Регистрация: 16.09.2012
Сообщений: 524
#1

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

25.10.2012, 17:56. Просмотров 1347. Ответов 2
Метки нет (Все метки)

В банкомате имеются в достаточном количестве купюры номиналом 10, 20, 50, 100, 200 и 500 гривен. Найти минимальное количество купюр, которое необходимо использовать, чтобы выдать сумму в n гривен или вывести -1, если указанную сумму выдать нельзя.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.10.2012, 17:56     Наименьшее количество купюр, которыми можно выдать n гривен
Посмотрите здесь:
C++ Найти минимальное количество купюр, которое необходимо использовать, чтобы выдать сумму в n гривен
Выдать наименьшее количество денег C++
Выдать N рублей минимальным набором купюр C++
6. Написать программу, которая предлагает пользователю ввести сумму в гривнах (дробное число) и выводит по отдельности количество гривен и количество C++
За какое наименьшее количество взвешиваний можно обнаружить фальшивую монету? C++
Выдать пары простых чисел, разность между которыми равна 4, а сами числа меньше n C++
C++ Как наименьшим количеством купюр можно выплатить денежную сумму x
Найти минимальное количество купюр для оплаты суммы C++
C++ Можно ли разменять m руб. на рублёвые, трёхрублёвые, пятирублёвые купюры так, чтобы получить всего 10 купюр
C++ 6. Можно ли разменять m руб. на рублёвые, трёхрублёвые, пятирублёвые купюры так, чтобы получить всего 10 купюр. (10<m<50)
C++ Пользователь трижды вводит достоинство купюр и их количество. Программа должна посчитать общую сумму денег
C++ Подсчет количества способов, которыми можно разменять рубль медными монетами (достоинством 1, 2, 3, 5 копеек)

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
valeriikozlov
Эксперт C++
4669 / 2495 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
25.10.2012, 21:05     Наименьшее количество купюр, которыми можно выдать n гривен #2
работает при n до 100000 включительно:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
using namespace std;
 
int main(void) {
    int a[100001]={0}, i, j, b[6]={10, 20, 50, 100, 200, 500}, n;
    for(i=0; i<6; i++)
        a[b[i]]=1;
    for(i=10; i<100001; i+=10)
    {
        for(j=0; j<6; j++)
            if(i+b[j]<100001 && a[i+b[j]]==0)
                a[i+b[j]]=a[i]+1;           
    }
    cin>>n;
    if(a[n]==0)
        cout<<-1<<endl;
    else
        cout<<a[n]<<endl;    
    return 0;
}
John Prick
773 / 706 / 129
Регистрация: 27.07.2012
Сообщений: 2,022
Завершенные тесты: 3
25.10.2012, 21:43     Наименьшее количество купюр, которыми можно выдать 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
28
29
30
31
32
33
34
35
36
37
38
39
/*
В банкомате имеются в достаточном количестве купюры
номиналом 10, 20, 50, 100, 200 и 500 гривен. Найти
минимальное количество купюр, которое необходимо использовать,
чтобы выдать сумму в n гривен или вывести -1, если
указанную сумму выдать нельзя.
*/
 
#include <iostream>
#include <vector>
#include <algorithm>
 
int main(void)
{
    setlocale(0, "rus");
    unsigned int Nom[] = { 10, 20, 50, 100, 200, 500 };
    std::vector<unsigned int> Nominals(Nom, Nom + sizeof(Nom)/sizeof(Nom[0]));
    std::sort(Nominals.begin(), Nominals.end());
 
    unsigned int n;
    std::cout << "Введите сумму: ";
    std::cin >> n;
 
    unsigned int MinNominal = *(std::min_element(Nominals.begin(), Nominals.end()));
    unsigned int bonds = 0;
    std::vector<unsigned int>::reverse_iterator NomIter = Nominals.rbegin();
    while ((n >= MinNominal) && (NomIter != Nominals.rend()))
    {
        unsigned int thisNomBonds = n / *NomIter;
        if (thisNomBonds > 0)
            std::cout << "Купюр по " << *NomIter << ": " << thisNomBonds << '\n';
        bonds += thisNomBonds;
        n %= *NomIter;
        ++NomIter;
    }
 
    std::cout << "Число купюр: " << ((n > 0) ? -1 : bonds) << std::endl;
    system("pause");
}
Yandex
Объявления
25.10.2012, 21:43     Наименьшее количество купюр, которыми можно выдать n гривен
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru