0 / 0 / 0
Регистрация: 20.02.2019
Сообщений: 29

По списку оценок определить вид диплома

25.02.2019, 20:58. Показов 2294. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Диплом
Имя входного файла: stdin
Имя выходного файла: stdout
Ограничение по времени: 2 seconds
Ограничение по памяти: 64 megabytes
Сергей скоро заканчивает обучение в институте. Уже написана пояснительная записка к выпускной квалификационной работе и оформлены все документы. Теперь Сергей задумался, не может ли
он получить по результатам обучения диплом с отличием. В официальных документах он нашел
следующее: «Студент получает диплом с отличием, если количество оценок “хорошо” не превышает
25% (в исключительных случаях допускается одна оценка “удовлетворительно” ». Более формально,
студент получает диплом с отличием, если у него не более одной оценки “удовлетворительно”, а количество оценок “хорошо” и “удовлетворительно” не превышает 25% от общего количества оценок.
Изучив свою зачетную книжку, Сергей составил список всех оценок, которые он получил за годы
обучения в институте. Список получился достаточно большим: оценок оказалось n штук. Напишите программу, которая по этому списку определит, какой диплом получит Сергей в соответствии с
указанным выше правилом.
Формат входных данных
Первая строка входного файла содержит число n (1 ⩽ n ⩽ 100000). Вторая строка входного
файла содержит n чисел, разделенные одним или несколькими пробелами — оценки Сергея. Числом
5 обозначается оценка “отлично”, числом 4 – оценка “хорошо”, числом 3 – оценка “удовлетворительно”.
Каждое число во второй строке равно либо 3, либо 4, либо 5.
Формат выходных данных
В выходной файл выведите «Degree with honors», если Сергей получает диплом с отличием, и
«Ordinary degree» иначе.
Примеры
stdin stdout
5
5 5 5 5 4
Degree with honors
4
3 3 4 5
Ordinary degree

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
#include <iostream> 
#include <string> 
using namespace std; 
 
int main(int argc, char* argv[]) 
{ 
int n,i;
float k,sum,tri,ch,l;
n=0;i=0;sum=0;tri=0;ch=0;
cin >> n;
int a[n];
for (int i=1;i<=n;i++)
{
    cin >> a[i];
    sum=sum+a[i];
    
    if (a[i]==3)
    {
        tri=tri+a[i];
    }
    if (a[i]==4)
    {
        ch=ch+a[i];
    }
}
l=tri+ch;
k=l/sum;
if ( tri<=3 && k<=0.25)
{
    cout << "Degree with honors";
}
else
{
    cout << "Ordinary degree";
}
return 0; 
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.02.2019, 20:58
Ответы с готовыми решениями:

Определить, какой вид пятиборья набрал максимальное значение по сумме всех оценок
В пятиборье участвует 10 спортсменов. Информация о результатах пятиборья предоставлены в виде таблицы, в которой строки это оценки по 10...

Вычислить общую сумму баллов, наихудшую и наилучшую оценку по списку оценок
Оператор цикла:for, while Известны оценки студента по 10 дисциплинам. Вычислить общую сумму баллов, наихудшую и наилучшую оценку

Вводя в цикле по 5 оценок каждого студента, подсчитать число студентов, не имеющих оценок 2 и 3
Помогите пожалуйста запутался) Вводя в цикле по 5 оценок каждого студента, подсчитать число студентов, не имеющих оценок 2 и 3. ...

1
Мозгоправ
 Аватар для L0M
1745 / 1039 / 468
Регистрация: 01.10.2018
Сообщений: 2,138
Записей в блоге: 2
26.02.2019, 13:23
Лучший ответ Сообщение было отмечено derhg3229 как решение

Решение

Всё проще
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
 
using namespace std;
 
int main() {
    int n;
    cin >> n;     // количество оценок
    int mark;     // текущая считанная оценка
    int three_cnt = 0, not_five_cnt = 0;    // счётчик троек и счётчик "не-пятёрок"
    for (int i = 0; i < n; ++i) {
        cin >> mark;
        if (mark < 5) {
            ++not_five_cnt;
            if (mark < 4)
                ++three_cnt;
        }
    }
    double no_good_part = double(not_five_cnt) / n;  // расчёт доли оценок ниже пятёрки (доля * 100 == %%)
    if (no_good_part > 0.25 || three_cnt > 1)
        cout << "Ordinary degree";
    else
        cout << "Degree with honors";
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.02.2019, 13:23
Помогаю со студенческими работами здесь

Определить количество неудолетворительных оценок
Уважаемые Форумчане помогите перевести задачу из язика Pascal в язик С++. Вот условие:Определить кол-во неудолитворительных оценок за...

Определить количество отличных оценок
Помогите решить задачу вот а вот методические указания и примеры Пожалуйста полностью распишите, а то вообще не шарю в с++

Определить, есть ли среди оценок двойки
Известны оценки по информатике 28 учеников класса. Есть ли среди них двойки?

Определить, есть ли тройки в списке оценок
Здравствуйте,помогите решить задачу на циклы,паскаль: Известны оценки по информатике 28 учеников из класса.Определить есть ли среди них...

Определить сумму оценок каждого ученика
Известны оценки двух учеников по четырем предметам. Определить сумму оценок каждого ученика.


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

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

Новые блоги и статьи
Компиляция C++ с Clang API
NullReferenced 24.03.2025
Компиляторы обычно воспринимаются как черные ящики, которые превращают исходный код в исполняемые файлы. Мы запускаем компилятор командой в терминале, и вуаля — получаем бинарник. Но что если нужно. . .
Многопоточное программировани­е в C#: Класс Thread
UnmanagedCoder 24.03.2025
Когда запускается приложение на компьютере, операционная система создаёт для него процесс - виртуальное адресное пространство. В C# этот процесс изначально получает один поток выполнения — главный. . .
SwiftUI Data Flow: Передача данных между представлениями
mobDevWorks 23.03.2025
При первом знакомстве со SwiftUI кажется, что фреймворк предлагает избыточное количество механизмов для передачи данных: @State, @Binding, @StateObject, @ObservedObject, @EnvironmentObject и другие. . . .
Моки в Java: Сравниваем Mockito, EasyMock, JMockit
Javaican 23.03.2025
Как протестировать класс, который зависит от других сложных компонентов, таких как базы данных, веб-сервисы или другие классы, с которыми и так непросто работать в тестовом окружении? Для этого и. . .
Архитектурные паттерны микросервисов: ТОП-10 шаблонов
ArchitectMsa 22.03.2025
Популярность микросервисной архитектуры объясняется множеством важных преимуществ. К примеру, она позволяет командам разработчиков работать независимо друг от друга, используя различные технологии и. . .
Оптимизация рендеринга в Unity: Сортировка миллиона спрайтов
GameUnited 22.03.2025
Помните, когда наличие сотни спрайтов в игре приводило к существенному падению производительности? Время таких ограничений уходит в прошлое. Сегодня геймдев сталкивается с задачами совершенно иного. . .
Образование и практика
Igor3D 21.03.2025
Добрый день А вот каково качество/ эффективность ВУЗовского образования? Аналитическая геометрия изучается в первом семестре и считается довольно легким курсом, что вполне справедливо. Ну хорошо,. . .
Lazarus. Таблица с объединением ячеек.
Massaraksh7 21.03.2025
Понадобилась представление на экране таблицы с объединёнными ячейками. И не одной, а штук триста, и все разные. На Delphi я использовал для этих целей TStringGrid, и то, кривовато получалось. А в. . .
Async/await в Swift: Асинхронное программировани­е в iOS
mobDevWorks 20.03.2025
Асинхронное программирование долго было одной из самых сложных задач для разработчиков iOS. В течение многих лет мы сражались с замыканиями, диспетчеризацией очередей и обратными вызовами, чтобы. . .
Колмогоровская сложность: Приёмы упрощения кода
ArchitectMsa 20.03.2025
Наверное, каждый программист хотя бы раз сталкивался с кодом, который напоминает запутанный лабиринт — чем дальше в него погружаешься, тем сложнее найти выход. И когда мы говорим о сложности кода, мы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru