Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/9: Рейтинг темы: голосов - 9, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 08.09.2017
Сообщений: 40

Сортировка Структуры

29.11.2017, 01:28. Показов 1820. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста, не получается исправить ошибку.
Суть: задается кафедра, по этой кафедре сортируются студенты и выводятся по возрастанию(В зависимости от кол-ва книг).
В моем случае выводит все кафедры подряд, хотя сортировка по кол-ву работает.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
        cout << "Введите название кафедры для сортировки:";
        cin >> kaf;
        system("cls");
        for (int i = 0; i <= n; i++) {
            if (strcmp(kaf, students[i].kafedra) == 0) {
                for (int j = 0; j < n; j++) {
                    if (students[j].kolvoknig > maxi) {
                        maxi = students[j].kolvoknig;
                        position = j;
                        cout << "Студент " << position + 1 << endl;
                        cout << "Имя:" << students[position].name << endl;
                        cout << "Фамилия:" << students[position].surname << endl;
                        cout << "Кафедра:" << students[j].kafedra << endl;
                        cout << "Кол-во книг:" << students[j].kolvoknig << endl << endl;
                    }
                }
            }
        }
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.11.2017, 01:28
Ответы с готовыми решениями:

Структуры. Сортировка массива структуры
Здравствуйте! В чем моя ошибка?? Нужно отсортировать массив структуры по возрастанию среднего балла?? Делаю это с помощью...

Структуры(сортировка)
есть программа с описание структуры......вбиваем начальный маршрут(точка отправки) и конечный(точка прибытия), а также его номер........ЭТА...

Структуры. Сортировка
Всем привет! Подскажите пожалуйста, если я создал структуру с тремя компонентами: &lt;имя&gt;,&lt;возраст&gt;,&lt;пол&gt; и я хочу...

5
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
29.11.2017, 10:45
И где здесь сортировка? Ты не переставляешь элементы.
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,532
Записей в блоге: 1
29.11.2017, 11:08
Лучший ответ Сообщение было отмечено Gnomee как решение

Решение

Все cout<< надо убрать нафиг, ты определённо сам не понимаешь, зачем оно тебе надо.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
    for (int i = 0; i < n-1; i++) {
        if (strcmp(kaf, students[i].kafedra) == 0) {
            position = i;
            maxi = students[i].kolvoknig;
            for (int j = i+1; j < n; j++) {
 
                if (strcmp(kaf, students[i].kafedra) == 0 && students[j].kolvoknig > maxi) {
                    maxi = students[j].kolvoknig;
                    position = j;
                }
            }
            tmp= students[i];
            students[i]= students[position];
            students[position] = tmp;
        }
    }
    for (int i = 0; i < n; i++) {
        cout << "Студент " << i << endl;
        cout << "Имя:" << students[i].name << endl;
        cout << "Фамилия:" << students[i].surname << endl;
        cout << "Кафедра:" << students[i].kafedra << endl;
        cout << "Кол-во книг:" << students[i].kolvoknig << endl << endl;
    }
1
0 / 0 / 0
Регистрация: 08.09.2017
Сообщений: 40
29.11.2017, 18:30  [ТС]
Kuzia domovenok, Так мне же нужно вывести полный список студентов, с индексом заданной кафедры, а если выводить таким образом, то будет выводить всю заданную базу студентов?

Добавлено через 3 минуты
Kuzia domovenok, Вы все правильно написали, но не совсем поняли условие, спасибо за помощь.
Вот таким образом мне нужно было вывести, что бы cout был внутри(Ваш код):
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
    case 2:
        cout << "Введите название кафедры для сортировки:";
        cin >> kaf;
        system("cls");
        for (int i = 0; i < n - 1; i++) {
            if (strcmp(kaf, students[i].kafedra) == 0) {
                position = i;
                maxi = students[i].kolvoknig;
                for (int j = i + 1; j < n; j++) {
                    if (strcmp(kaf, students[i].kafedra) == 0 && students[j].kolvoknig > maxi) {
                        maxi = students[j].kolvoknig;
                        position = j;
                    }
                }
                tmp = students[i].kolvoknig;
                students[i] = students[position];
                students[position].kolvoknig = tmp;
                cout << "Студент " << i << endl;
                cout << "Имя:" << students[i].name << endl;
                cout << "Фамилия:" << students[i].surname << endl;
                cout << "Кафедра:" << students[i].kafedra << endl;
                cout << "Кол-во книг:" << students[i].kolvoknig << endl << endl;
            }
        }
        break;
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,532
Записей в блоге: 1
29.11.2017, 18:38
Gnomee, ты понимаешь, что сортировка и вывод это две разные задачи? Тебе вчера весь вечер об этом твердили в другой теме, но ты просто упорото пихаешь вывод в цикл сортировки! Что с тобой не так-то?

Ну один раз смешал своих мух с котлетами, ну проверь тогда уж как это будет работать, убедись в том что не будет и не пихай больше cout в цикл! Нет, будем вторые сутки этот вопрос обсасывать!

Я не сразу понял, что нужно не просто всех выводить вместе, тогда я сделаю так:
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
    for (int i = 0; i < n-1; i++) {
        if (strcmp(kaf, students[i].kafedra) == 0) {
            position = i;
            maxi = students[i].kolvoknig;
            for (int j = i+1; j < n; j++) {
 
                if (strcmp(kaf, students[i].kafedra) == 0 && students[j].kolvoknig > maxi) {
                    maxi = students[j].kolvoknig;
                    position = j;
                }
            }
            tmp= students[i];
            students[i]= students[position];
            students[position] = tmp;
        }
    }
    for (int i = 0; i < n; i++) {
        if (strcmp(kaf, students[i].kafedra) == 0) {
           cout << "Студент " << i << endl;
           cout << "Имя:" << students[i].name << endl;
           cout << "Фамилия:" << students[i].surname << endl;
           cout << "Кафедра:" << students[i].kafedra << endl;
           cout << "Кол-во книг:" << students[i].kolvoknig << endl << endl;
        }
    }
Обрати внимание, что даже в этом случае я не пихаю вывод в сортировку
0
0 / 0 / 0
Регистрация: 08.09.2017
Сообщений: 40
29.11.2017, 21:20  [ТС]
Kuzia domovenok, Наконец то понял о чем вы говорите

Добавлено через 27 минут
Kuzia domovenok, Как исправить ошибку?

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
        const int n = 10;
struct Lib //Структура библиотека
{
    char name[20];
    char surname[20];
    char kafedra[20];
    int kolvoknig;
} students[n];
 
int main() //Студенты
{
    Lib students[n] =
    {
        { "Kolya","Bob","EM",5 },
        { "Nikita","Chaee","TM",8 },
        { "Sasha","Kesys","EM",10 },
        { "Misha","Loesa","RT",1 },
        { "Mikola","Doper","TM",3 },
        { "Elena","Ewosha","PR",14 },
        { "Alena","Soawp","PR",7 },
        { "Evgenyi","Sdweas","PR",15 },
        { "Mixail","Chpor","TM",3 },
        { "Oleg","Necheer","RT",2 },
    };
 
// В данном месте ошибка
        tmp = students[i];
        students[i] = students[position];
        students[position] = tmp;
Добавлено через 1 час 59 минут
/del
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.11.2017, 21:20
Помогаю со студенческими работами здесь

Сортировка структуры
Есть структура struct v{ string one; string two; int three; }; Подскажите как отсортировать массив структур по полю...

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

Структуры. Сортировка
Здравствуйте, ув. форумчане. Я студент 1ого курса и только недавно начал изучать C++, учился по видеоурокам, но застрял на структурах, не...

Сортировка и структуры
Задача : &quot;Имеется список 10 политических деятелей. Каждый из 100 опрошенных называет трех политиков, и назначает каждому из них одно из...

Сортировка структуры
Отсортировать структуру по желанию пользователя. 1. Вывести на экран книги в алфавитном порядке с указанием авторов, 2. Число книг...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru