Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
Faul969
1 / 1 / 0
Регистрация: 08.10.2010
Сообщений: 28
#1

про маршутку - C++

18.10.2010, 20:11. Просмотров 796. Ответов 2
Метки нет (Все метки)

В час пик на остановку одновременно подъехали три маршрутных такси, следующие по одному
маршруту, в которые тут же набились пассажиры. Водители обнаружили, что количество людей в
разных маршрутках разное, и решили пересадить часть пассажиров так, чтобы в каждой маршрутке
было поровну пассажиров. Требуется определить, какое наименьшее количество пассажиров придется
при этом пересадить.
Программе вводится три натуральных числа, не превосходящих 100 - количества пассажиров в первой,
второй и третьей маршрутках соответственно.
Программа должна выводить одно число - наименьшее количество пассажиров, которое требуется
пересадить. Если это невозможно, выведите слово IМРОSIВLЕ.
Примеры:
Ввод: 1 2 3 Вывод: 1
Ввод: 99 100 100 Вывод: IМРОSIВLЕ
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.10.2010, 20:11
Здравствуйте! Я подобрал для вас темы с ответами на вопрос про маршутку (C++):

Про линковку библиотек и про архитектуру иерархии классов - C++
Добрый день! Возникла такая вот проблема. Я использую MinGW Developer Studio. Это довольно старая IDE, поддержка которой завершилась в 2005...

Про линковку и про исключения - C++
1) class method definition - если его поместить в объявлении класса в файле заголовке и включить заголовок в несколько компилируемых cpp, а...

1.про функция exit(); 2.про this - C++
1.Где находиться функция exit(1); А то в одних програмах подключають <stdlib.h>//для функции exit В других: <process.h>//для...

Про if - C++
double value1=0; double value2=0; double value3=0; cout<<"enter tree integer: "; ...

Про С++ - C++
Вот вопрос... В С++ довольно большой синтаксис. В одной СТЛ только сколько всего. Вопрос к опытным людям, вы это все запоминаете? Или же...

про \x - C++
в книге кернигана и ричи увидел упражнение узнать что такое \х,зашел в в.студио написал такой код printf("aaa\xasd"); и что получается ...

2
PointsEqual
ниначмуроФ
836 / 520 / 33
Регистрация: 12.10.2009
Сообщений: 1,915
18.10.2010, 20:49 #2
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
#include <iostream>
 
using namespace std;
 
/*
В час пик на остановку одновременно подъехали три маршрутных такси, следующие по одному
маршруту, в которые тут же набились пассажиры. Водители обнаружили, что количество людей в
разных маршрутках разное, и решили пересадить часть пассажиров так, чтобы в каждой маршрутке
было поровну пассажиров. Требуется определить, какое наименьшее количество пассажиров придется
при этом пересадить.
Программе вводится три натуральных числа, не превосходящих 100 - количества пассажиров в первой,
второй и третьей маршрутках соответственно.
Программа должна выводить одно число - наименьшее количество пассажиров, которое требуется
пересадить. Если это невозможно, выведите слово IМРОSIВLЕ.
Примеры:
Ввод: 1 2 3 Вывод: 1
Ввод: 99 100 100 Вывод: IМРОSIВLЕ
*/
int max(int a, int b){
    return (a > b) ? a : b;
}
 
int xpassanger(int a, int b, int c){
    int s = a + b + c;
    return (s%3) ? (-1) : (max(max(a,b),c) - (s / 3));
}
 
 
int main()
{
    int res;
    res = xpassanger(1,2,3);
 
    if (res == -1) cout << "IMPOSSIBLE";
    else cout << res;
 
    return 0;
}
0
Mr.X
Эксперт С++
3051 / 1696 / 265
Регистрация: 03.05.2010
Сообщений: 3,867
20.10.2010, 01:54 #3
PointsEqual, программа неправильно работает при вводе значений 4, 4, 1.
Правильное решение:
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
68
69
70
71
72
73
74
75
76
77
78
79
80
///////////////////////////////////////////////////////////////////////////////////
//В час пик на остановку одновременно подъехали три маршрутных такси, 
//следующие по одному маршруту, в которые тут же набились пассажиры. 
//Водители обнаружили, что количество людей в разных маршрутках разное, 
//и решили пересадить часть пассажиров так, чтобы в каждой маршрутке
//было поровну пассажиров. Требуется определить, какое наименьшее 
//количество пассажиров придется при этом пересадить. 
///////////////////////////////////////////////////////////////////////////////////
#include <iostream>
#include <numeric>
#include <vector>
///////////////////////////////////////////////////////////////////////////////////
typedef std::vector<int>  T_nums;
///////////////////////////////////////////////////////////////////////////////////
struct T_add_surplus
{
    int  average_val_;
    T_add_surplus(int average_val) : average_val_(average_val)
    {}
    //-----------------------------------------------------------------------------
    int operator() (int sum, int cur_val)
    {
        int surplus = cur_val - average_val_;
        
        return sum + (surplus > 0 ? surplus : 0);
    }
};
///////////////////////////////////////////////////////////////////////////////////
int  replaced_passengers_count(T_nums  nums)
{
    int sum = std::accumulate(nums.begin(), nums.end(), 0);
    if(sum % nums.size() != 0)
    {
        return -1;
    }
    int average_val = sum / nums.size();
    return std::accumulate(nums.begin(), nums.end(), 0, T_add_surplus(average_val));
}
///////////////////////////////////////////////////////////////////////////////////
int main()
{
    std::locale::global(std::locale(""));
    for(;;)
    {
        std::cout << "Введите количество маршруток: ";
        int n;
        std::cin >> n;
        if(n <= 0)
        {
            break;
        }
        
        T_nums  nums(n);
        std::cout << "Введите число пассажиров в каждой маршрутке: "
                  << std::endl;
        for(int i = 0; i < n; ++i)
        {
            std::cout << "#"
                      << i + 1
                      << ": ";
            std::cin >> nums[i];
        }
        int res = replaced_passengers_count(nums);
        if(res < 0)
        {
            std::cout << "Нет решения.";
        }
        else
        {
            std::cout << "Чтобы в маршрутках пассажиров было поровну, нужно пересадить "
                      << res
                      << " пассажиров.";
 
        }
        std::cout << std::endl
                  << std::endl
                  << std::endl
                  << std::endl;    
    }
}
2
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
20.10.2010, 01:54
Привет! Вот еще темы с ответами:

про while. - C++
Дошел по учебнику до while и появился непонятный для меня момент. Пока я не напишу букву &quot;q&quot;, программа считывает введенные оценки. А...

Про указатели - C++
Здравствуйте я совсем маленький C++ программер, вот сейчас разбираюсь с указателями. Подскажите пожалуйста. В книге встретил пример,...

Про Соседей - C++
На плоскости заданы N точек своими координатами. Найти количество точек, которые в окрестности радиуса R не имеет &quot;соседей&quot;. ПОМОГИ...

Про указатели - C++
В среде C++ Builder разбираюсь с логикой работы с указателями. По определению (в моем его понимании) указатель это адрес в памяти на...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

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