Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
15 / 15 / 21
Регистрация: 13.11.2014
Сообщений: 275

Реализовать сортировку массива структур по заданному полю

06.02.2016, 15:48. Показов 1058. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите правильно отсортировать структуры по среднему балу и записать их в файл
структура:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
struct student
{
    char name[64];
    int course;
    char group[64];
    int age;
    float mean; 
    struct mark
    {
        int math;
        int programming;
        int physics;
        int ict;
    } mark;
};
функция записи
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
int RW(int n)
{
    setlocale(LC_ALL, "Ukrainian");
    int i;
    student pos;
    cout << "Введiть кiлькiсть студентiв" << endl;
    cin >> n;
    student *typed = new student[n];
    ofstream inf("Info.DAT");
    for (i = 0; i < n; i++)
    {
        cout << "Введiть прiзвище " << i + 1 << " cтудента ";
        cin >> typed[i].name;
        cout << "Введiть курс " << i + 1 << " cтудента ";
        cin >> typed[i].course;
        cout << "Введiть групу " << i + 1 << " cтудента ";
        cin >> typed[i].group;
        cout << "Введiть вiк " << i + 1 << " cтудента ";
        cin >> typed[i].age;
        cout << "Введiть оцiнку з iТС " << i + 1 << " cтудента ";
        cin >> typed[i].mark.ict;
        cout << "Введiть оцiнку з математики " << i + 1 << " cтудента ";
        cin >> typed[i].mark.math;
        cout << "Введiть оцiнку з фiзики " << i + 1 << " cтудента ";
        cin >> typed[i].mark.physics;
        cout << "Введiть оцiнку з програмування " << i + 1 << " cтудента ";
        cin >> typed[i].mark.programming;
        typed[i].mean = (typed[i].mark.ict + typed[i].mark.math + typed[i].mark.physics + typed[i].mark.programming) / 4.0;
    }
        for (i = 1; i < n; i++)
        {
            int p = i;
            pos = typed[i];
            for (int j = i+1; j < n; j++)
            {
                if (typed[j].mean>typed[j+1].mean)
                {
                    p = j;
                    pos = typed[j];
                    
                }
                typed[p] = typed[i];
                typed[i] = pos;
            }
        }
        for (int i = 0; i < n; i++)
        {
            inf << "iм'я " << typed[i].name << endl;
            inf << "Курс " << typed[i].course << endl;
            inf << "Група " << typed[i].group << endl;
            inf << "Вiк " << typed[i].age << endl;
            inf << "iСТ " << typed[i].mark.ict << endl;
            inf << "Математика " << typed[i].mark.math << endl;
            inf << "Фiзика " << typed[i].mark.physics << endl;
            inf << "Програмування " << typed[i].mark.programming << endl;
            inf << "" << typed[i].mean << endl;
            inf << "-----------------------------------------" << endl;
        }
    
    inf.close();
    return 0;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.02.2016, 15:48
Ответы с готовыми решениями:

Реализовать сортировку массива объектов пользовательского типа по заданному полю (структуры)
Есть перечень студентов, прибывших в лагерь по форме: ФИО, факультет, номер отряда. Упорядочить перечень по номерам отрядов, внутри отряда...

Реализовать структуру моделирующую работу аэропорта; реализовать поиск по заданному полю в массиве таких структур
Здравствуйте. Каким образом можно сделать ввод данных через массив, а так же все последующие действия в соответствии с заданием? То есть, я...

Реализовать сортировку объектов пользовательского типа по заданному полю
Помогите организовать сортировку по полю класса id, уже голова пухнет void HomeLib::set_sortBook_ID() { Book* pv = beg; ...

3
 Аватар для Alexander Bakay
100 / 52 / 39
Регистрация: 15.12.2015
Сообщений: 329
06.02.2016, 18:22
а что здесь такого, возьмите обычную сортировку(хоть ту же пузырьком), но действие:
C++
1
2
3
int tmp= typed[j].mean; 
        typed[j].mean = typed[j+1].mean;
        typed[j+1].mean = tmp;
в её алгоритме, проделайте для каждого элемента структуры(name,course,group,age,mean)
0
15 / 15 / 21
Регистрация: 13.11.2014
Сообщений: 275
06.02.2016, 18:39  [ТС]
если честно , я ничего не понял.
0
3 / 3 / 4
Регистрация: 03.07.2014
Сообщений: 19
07.02.2016, 04:12
Ошибка в сортировке имеется + в присвоении структурной переменной. Это же классическая сортировка пузырьком.
Попробуй вот такой код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
for (i = 0; i < n-1; i++)
{
    for (int j = 0; j < n-i-1; j++)
    {
        if (typed[j].mean>typed[j+1].mean)
        {
            student temp;
            memcpy(&temp,&typed[j],sizeof(student));
            memcpy(&typed[j],&typed[j+1],sizeof(student));
            memcpy(&typed[j+1],&temp,sizeof(student));
        }
    }
}
Не забудь подключить:
C++
1
#include <stdlib.h>
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.02.2016, 04:12
Помогаю со студенческими работами здесь

Реализовать поиск в массиве структур по заданному полю
Есть структура #include &lt;iostream&gt; #include &lt;fstream&gt; #include &lt;conio.h&gt; #include &lt;iomanip&gt; using namespace...

Реализовать поиск в массиве структур по заданному полю
Задание : Определить тип данных запись, имеющий поля фамилия и оценки по 5 предметам.Определить массив из 10 записей.В программе ввести в...

Реализовать поиск и сортировку по заданному полю в списке объектов пользовательского типа
Доброго времени суток. Дали задачу &quot;Запись о багаже пассажира содержит: фамилия, номер рейса, дата время вылета, пункт назначения, кол-во...

Реализовать сортировку и поиск по заданному полю в массиве пользовательского типа (файловый ввод/вывод)
Подскажите, как реализовать часть задания, которая выделена красным цветом. Построить иерархию классов для контрольных мероприятий,...

Реализовать поиск и сортировку по заданному полю в массиве объектов пользовательского типа (структура Train)
Описать структуру с именем TRAIN, содержащую следующие поля: NAZV - название пункта назначения, NUMR - номер поезда, DATE - дата отправки,...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru