Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
TheSN
153 / 95 / 12
Регистрация: 25.02.2012
Сообщений: 232
18.11.2013, 10:18     Выведите фамилии и имена учащихся в порядке убывания их среднего балла #1
Помогите, пожалуйста, с решением, последний тест не проходит, пишет "превышено максимальное время работы".
Вместо пузырька вставляли другие сортировки, ничего не помогло.

Задание

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

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

Заданы сначала количество учащихся 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;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.11.2013, 10:18     Выведите фамилии и имена учащихся в порядке убывания их среднего балла
Посмотрите здесь:

Вычисление среднего балла C++
C++ Выведите все числа от A до B включительно, в порядке возрастания, если A < B, или в порядке убывания в противном случае.
Работа с файлами. Выведите список авторов в порядке убывания популярности, и названия издательств, которые публиковали их книги. C++
Структура. Вывести информацию по студентам в порядке уменьшения среднего балла C++
C++ Выведите фамилии и имена студентов в порядке убывания их среднего балла
C++ Составить список учащихся в списке в порядке убывания
C++ Вывести имена файлов в порядке убывания размера файла

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
18.11.2013, 10:24     Выведите фамилии и имена учащихся в порядке убывания их среднего балла #2
Почему не файл с данными, а ручной ввод?
d1skort
20 / 20 / 0
Регистрация: 10.02.2013
Сообщений: 75
18.11.2013, 14:19     Выведите фамилии и имена учащихся в порядке убывания их среднего балла #3
Пузырьковая сортировка? Ее временная сложность - O(n^2)

Судя по заданию тебе нужна устойчивая сортировка.
Используй сортировку слиянием. Временная сложность - O(n*lgn)
Yandex
Объявления
18.11.2013, 14:19     Выведите фамилии и имена учащихся в порядке убывания их среднего балла
Ответ Создать тему
Опции темы

Текущее время: 21:21. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru