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

Благотворительность в царстве

11.10.2016, 15:03. Показов 3815. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Уххх,просто не пойму,как решать (С объяснением)

В царстве-государстве решено было собрать с людей-богачей пожертвования на благотворительность. Все согласились, что пожертвование должен сделать самый богатый из людей-богачей. Известны финансовые состояния четырех людей-богачей A, B, C, D. Определите, сколько денег останется у каждого из них после пожертвования, если сумма пожертвования составляет N дубиков. Если по каким-то причинам богатейший из людей-богачей обанкротится в процессе пожертвования, то оставшиеся дубики должен будет заплатить следующий богатейший, а если обанкротится и он, то следующий после него и так далее.

В единственной строке необходимо вывести 4 числа —- финансовые состояния людей-богачей после пожертвования.

Пример :
Ввод :

1000000 900000 750000 800000
100000
Вывод:
900000 900000 750000 800000
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.10.2016, 15:03
Ответы с готовыми решениями:

Нужна благотворительность
Занимаюсь созданием правдоподобной (с физической точки зрения) 3D модели солнечной системы. Необходимо обозначить спутники планет...

В некоторм царстве правил король.
В некотором царстве правил король. Однажды он решил провести эксперимент над заключенными.В одну из комнат посадим очаровательную...

А нужна ли в программировании благотворительность?
Всем привет! Как Вы относитесь к созданию благотворительных проектов в программировании? Например, бесплатные социальные сети, бесплатные...

3
Падаван С++
 Аватар для obivan
447 / 261 / 89
Регистрация: 11.11.2014
Сообщений: 916
11.10.2016, 15:17
DoctorKto,
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
#include <iostream>
#include <vector>
#include <cmath>
 
int main(int argc, char* argv[])
{
    const int peopleCount = 4;
    std::vector<int> richPeopleMoney;
    int moneyToTake;
    
    for(int i(0), tmp; i < peopleCount; ++i) {
        std::cout << "Enter money of " << i + 1 << " guy " << std::endl;
        std::cin >> tmp;
        richPeopleMoney.push_back(tmp);
    }
    
    std::cout << "Enter money to take: ";
    std::cin >> moneyToTake;
    
    for(int i(0); i < richPeopleMoney.size(); ++i) {
        richPeopleMoney[i] -= moneyToTake;
        
        if(richPeopleMoney[i] >= 0) 
            break;
        
        moneyToTake = abs(richPeopleMoney[i]);
        richPeopleMoney[i] = 0;
    }
    
    std::cout << "\nResult:" << std::endl;
    for(int i(0); i < richPeopleMoney.size(); ++i)
        std:: cout << richPeopleMoney[i] << " ";
    
    return 0;
}
1
0 / 0 / 1
Регистрация: 23.03.2016
Сообщений: 40
11.10.2016, 15:36  [ТС]
Можно вас попросить сделать только с IF - Без For?

Цитата Сообщение от obivan Посмотреть сообщение
DoctorKto,
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
#include <iostream>
#include <vector>
#include <cmath>
 
int main(int argc, char* argv[])
{
    const int peopleCount = 4;
    std::vector<int> richPeopleMoney;
    int moneyToTake;
    
    for(int i(0), tmp; i < peopleCount; ++i) {
        std::cout << "Enter money of " << i + 1 << " guy " << std::endl;
        std::cin >> tmp;
        richPeopleMoney.push_back(tmp);
    }
    
    std::cout << "Enter money to take: ";
    std::cin >> moneyToTake;
    
    for(int i(0); i < richPeopleMoney.size(); ++i) {
        richPeopleMoney[i] -= moneyToTake;
        
        if(richPeopleMoney[i] >= 0) 
            break;
        
        moneyToTake = abs(richPeopleMoney[i]);
        richPeopleMoney[i] = 0;
    }
    
    std::cout << "\nResult:" << std::endl;
    for(int i(0); i < richPeopleMoney.size(); ++i)
        std:: cout << richPeopleMoney[i] << " ";
    
    return 0;
}
0
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
11.10.2016, 15:36
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/////////////////////////////////////////////////////////////////////
// В царстве-государстве решено было
// собрать с людей-богачей пожертвования на благотворительность. 
// Все согласились, 
// что пожертвование должен сделать самый богатый из людей-богачей. 
// Известны финансовые состояния четырех людей-богачей A, B, C, D. 
// Определите, 
// сколько денег останется у каждого из них после пожертвования, 
// если сумма пожертвования составляет N дубиков. 
// Если по каким-то причинам богатейший 
// из людей-богачей обанкротится в процессе пожертвования, 
// то оставшиеся дубики должен будет заплатить следующий богатейший, 
// а если обанкротится и он, то следующий после него и так далее.
 
// В единственной строке необходимо вывести 4 числа
// - финансовые состояния людей-богачей после пожертвования.
 
// Пример :
// Ввод : 
// 1000000 900000 750000 800000
// 100000
// Вывод: 
// 900000 900000 750000 800000
/////////////////////////////////////////////////////////////////////
#include <iostream>
#include <algorithm>
#include <cstdlib>
/////////////////////////////////////////////////////////////////////
int main()
{
    int rich[4]{};
    int donating{};
    
    for( int& it : rich )
    {
        std::cin >> it;
    }
    
    std::cin
        >> donating;
    
    int* max;
    
    for( int i{}; i < 4; ++i )
    {
        max = std::max_element( rich, rich + 4 );
        
        *max -= donating;
        
        if( *max < 0 )
        {
            donating = std::abs( *max );
            *max = 0;
            
            continue;
        }
        else
        {
            break;
        }
    }
    
    for( int& it : rich )
    {
        std::cout << it << ' ';
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.10.2016, 15:36
Помогаю со студенческими работами здесь

В одномерном массиве хранится информация об отчислениях на благотворительность каждой из 15 фирм
В одномерном массиве хранится информация об отчислениях на благотворительность каждой из 15 фирм. Определить: а) общую сумму ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru