Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 07.01.2018
Сообщений: 17
1

Задача про структуры

07.12.2018, 01:35. Показов 1351. Ответов 1

Добрый преподаватель Иванов Иван Иваныч решил на последнем занятии улучшить всем ребятам из его класса средний балл. Для этого он решил добавлять им пятерки, пока средний балл не станет равен хотя бы 4.5.

Напишите функцию void add_mark(Student &s, int mark), которая добавляет ученику s оценку mark.

Считайте с клавиатуры 5 учащихся, которые учатся у Ивана Иваныча, подредактируйте их оценки, и выведите новый журнал учащихся.

Формат входных данных:
C клавиатуры подряд вводятся описания 5 учеников: имя и фамилия (слова из латинских букв не длиннее 50 символов), возраст (натуральное число, не превышающее 100), класс (целое число от 1 до 11), количество оценок ( целое неотрицательно число, не превышающее 30), оценки. Каждая из оценок — целое число от 2 до 5.

Формат выходных данных
Требуется вывести 5 учащихся в том же формате, в котором они и вводились (но без перевода строк между учениками).

Примеры:
входные данные

Bill Gates 15 7 3
2 5 3

Sergey Brin 10 4 5
5 3 4 5 4

Linus Torvalds 12 5 2
4 5

Larry Ellison 17 11 4
4 4 4 4

Steve Jobs 16 9 3
2 2 3

выходные данные
Bill Gates 15 7 10
2 5 3 5 5 5 5 5 5 5

Sergey Brin 10 4 8
5 3 4 5 4 5 5 5

Linus Torvalds 12 5 2
4 5
Larry Ellison 17 11 8
4 4 4 4 5 5 5 5

Steve Jobs 16 9 16
2 2 3 5 5 5 5 5 5 5 5 5 5 5 5 5

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
#include <iostream>
#include <string>
using namespace std;
 
struct student {
    string name;
    string second_name;
    int age;
    int clas;
    int num_marks;
    int marks[30];
};
void add_mark(student &s)
{
    double average = 0;
    for (int i = 0; i < s.num_marks; i++)
        average += s.marks[i];
    average /= s.num_marks;
    while (average < 4.5)
    {
        s.marks[s.num_marks] = 5;
        s.num_marks += 1;
        for (int i = 0; i < s.num_marks; i++)
            average += s.marks[i];
        average /= s.num_marks;
    }
}
 
int main()
{
    student a;
    cin >> a.name >> a.second_name >> a.age >> a.clas >> a.num_marks;
    for (int i = 0; i < a.num_marks; i++)
        cin >> a.marks[i];
    student b;
    cin >> b.name >> b.second_name >> b.age >> b.clas >> b.num_marks;
    for (int i = 0; i < b.num_marks; i++)
        cin >> b.marks[i];
    student c;
    cin >> c.name >> c.second_name >> c.age >> c.clas >> c.num_marks;
    for (int i = 0; i < c.num_marks; i++)
        cin >> c.marks[i];
    student d;
    cin >> d.name >> d.second_name >> d.age >> d.clas >> d.num_marks;
    for (int i = 0; i < d.num_marks; i++)
        cin >> d.marks[i];
    student e;
    cin >> e.name >> e.second_name >> e.age >> e.clas >> e.num_marks;
    for (int i = 0; i < e.num_marks; i++) 
        cin >> e.marks[i];
    add_mark(a);
    add_mark(b);
    add_mark(c);
    add_mark(d);
    add_mark(e);
    cout << a.name << " " << a.second_name << " " << a.age << " " << a.clas << " " << a.num_marks << endl;
    for (int i = 0; i < a.num_marks; i++)
        cout << a.marks[i] << " ";
    cout << endl;
    cout << b.name << " " << b.second_name << " " << b.age << " " << b.clas << " " << b.num_marks << endl;
    for (int i = 0; i < b.num_marks; i++)
        cout << b.marks[i] << " ";
    cout << endl;
    cout << c.name << " " << c.second_name << " " << c.age << " " << c.clas << " " << c.num_marks << endl;
    for (int i = 0; i < c.num_marks; i++)
        cout << c.marks[i] << " ";
    cout << endl;
    cout << d.name << " " << d.second_name << " " << d.age << " " << d.clas << " " << d.num_marks << endl;
    for (int i = 0; i < d.num_marks; i++)
        cout << d.marks[i] << " ";
    cout << endl;
    cout << e.name << " " << e.second_name << " " << e.age << " " << e.clas << " " << e.num_marks << endl;
    for (int i = 0; i < e.num_marks; i++)
        cout << e.marks[i] << " ";
    system("pause");
    return 0;
}
Не могу понять в чём же ошибка, помогите пожалуйста.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
07.12.2018, 01:35
Ответы с готовыми решениями:

Задача про взлом кода из книги Эрика Фримена про основы javascript в конце 5 главы.
читаю книгу Эрика Фримена про основы javascript.В конце 5 главы есть задачка про взлом кода.Никак...

Задача на перебор вариантов. Задача Л.Эйлера. Про чиновника
Задача Л.Эйлера. Некий чиновник купил лошадей и быков на сумму 1770 талеров. За каждую лошадь он...

Легкий пример про структуры
Задача заключается в том чтобы присвоить значения переменной х и всем объектам к которым она имеет...

Хорошие книги про структуры данных
Можете что нибудь посоветовать?

1
Nishen
07.12.2018, 01:37     Задача про структуры
  #2

Не по теме:

Цитата Сообщение от artemchaiok2332 Посмотреть сообщение
Иван Иваныч
ищет новую работу на hh.ru, а Вы? :D

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
07.12.2018, 01:37
Привет! Вот еще темы с ответами:

списковые структуры (снова про ферьзей)
С помощью предиката queens 3-х аргументов, найдите все правильные расстановки ферзей на шахматной ...

Подскажите литературу про алгоритмы и структуры данных
Уважаемые форумчане, ткните пожалуйста носом какую литературу почитать про алгоритмы и структуры...

Подскажите пожалуйста где можно почитать про структуры
Подскажите пожалуйста где можно почитать про структуры Добавлено через 1 минуту Структуры – это...

Где можно прочитать про перевод структуры в массив
Здравствуйте! Подскажите где можно прочитать про перевод структуры в массив? У меня такая...


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

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

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