Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/13: Рейтинг темы: голосов - 13, средняя оценка - 5.00
155 / 97 / 101
Регистрация: 25.02.2012
Сообщений: 232
1

Выведите фамилии и имена учащихся в порядке убывания их среднего балла

18.11.2013, 10:18. Показов 2675. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Помогите, пожалуйста, с решением, последний тест не проходит, пишет "превышено максимальное время работы".
Вместо пузырька вставляли другие сортировки, ничего не помогло.

Задание

Выведите фамилии и имена учащихся в порядке убывания их среднего балла.

Формат входных данных

Заданы сначала количество учащихся n, затем n строк, каждая из которых содержит фамилию, имя и три числа (оценки по трем предметам: математике, физике, информатике). Данные в строке разделены одним пробелом. Оценки принимают значение от 1 до 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
#include <iostream>
#include <cstring>
using namespace std;
struct base {
       string fam;
       string im;
       int sr;
};
 
int main() {
    long n;
    cin >> n;
    base a[n];
    int m1 = 0, m2 = 0, m3 = 0;
    for (long i = 0; i < n; i++) {
        cin >> a[i].fam >> a[i].im >> m1 >> m2 >> m3;
        a[i].sr = m1 + m2 + m3;
    }
    for (long i = 1; i < n; i++) {
        for (long j = n - 1; j >= i; j--) {
            if (a[j].sr > a[j - 1].sr) swap(a[j], a[j - 1]);
        }
    }   
    for (long i = 0; i < n; i++) {
        cout << a[i].fam << " " << a[i].im << endl;
    }
    system("pause");
    return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
18.11.2013, 10:18
Ответы с готовыми решениями:

Выведите фамилии и имена учащихся в порядке убывания их среднего балла
Выведите фамилии и имена учащихся в порядке убывания их среднего балла. Формат входных данных ...

Выведите фамилии и имена студентов в порядке убывания их среднего балла
Выведите фамилии и имена студентов в порядке убывания их среднего балла

Выведите фамилии и имена учащихся в порядке убывания их среднего балла
1) Выведите фамилии и имена учащихся в порядке убывания их среднего балла. Входные данные...

Выведите фамилии и имена учащихся в порядке убывания их среднего балла
Выведите фамилии и имена учащихся в порядке убывания их среднего балла. Входные данные Заданы...

2
5498 / 4893 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
18.11.2013, 10:24 2
Почему не файл с данными, а ручной ввод?
0
20 / 20 / 8
Регистрация: 10.02.2013
Сообщений: 75
18.11.2013, 14:19 3
Пузырьковая сортировка? Ее временная сложность - O(n^2)

Судя по заданию тебе нужна устойчивая сортировка.
Используй сортировку слиянием. Временная сложность - O(n*lgn)
0
18.11.2013, 14:19
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
18.11.2013, 14:19
Помогаю со студенческими работами здесь

Напечатать на экран фамилии студентов в порядке убывания среднего балла
Дан фаил содержащий сведение о студентах группы.Каждая запись файла содержит:Фамилию и инициалы...

Структура: Выведите фамилии и имена учащихся, не имеющих троек (а также двоек и колов)...
Выведите фамилии и имена учащихся, не имеющих троек (а также двоек и колов). Входные данные...

Отсортировать данные в порядке убывания среднего балла
Задан массив записей, в котором определены поля Ф.И.О. студента и его средний балл....

Сортировка структур в порядке убывания среднего балла
П.5.18.Правил Запрещено размещать задания и решения в виде картинок и других файлов с их текстом....


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru