Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.85/40: Рейтинг темы: голосов - 40, средняя оценка - 4.85
55 / 39 / 18
Регистрация: 21.05.2015
Сообщений: 184

Сортировка записей Структуры по алфавиту

24.10.2017, 22:24. Показов 7944. Ответов 49
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
#include <iostream>
#include <iomanip>
using namespace std;
struct STUD // Структура STUD
{        
    char *Name; // Фамилия и инициалы          
    char *GROUP;  // Название группы (факультет, курс, номер группы)
    float SES [4]; // Успеваемость (баллы)
};                 
int main()
{
    setlocale (LC_ALL, ""); // подключение русского языка
    int STUD1_size = 10; // количество записей
    STUD STUD1[STUD1_size]; // массив STUD1 из 10 структур типа STUD
    int counter = 0; // счётчик записей
    while (counter < STUD1_size) // пока не внесено 10 записей
    {
        cout << "Введите Фамилию и инициалы через пробел: ";
        cin.getline(STUD1[counter].Name,20);
        cout << "Введите Название группы (факультет, курс, номер группы) через пробел: ";
        cin.getline(STUD1[counter].GROUP,10);
        cout << "Введите баллы через точку (округление до 0.1): ";
        cin >> setw(3) >> STUD1[counter].SES[0]; // считать первые три символа, первый балл
        cin.ignore(); // пропустить символ точки
        cin >> setw(3) >> STUD1[counter].SES[1]; // считать следующие три символа, второй балл
        cin.ignore(); // пропустить символ точки
        cin >> setw(3) >> STUD1[counter].SES[2]; // считать следующие три символа, третий балл
        cin.ignore(); // пропустить символ точки
        cin >> setw(3) >> STUD1[counter].SES[3]; // считать последние три символа, четвёртый балл
        cin.get(); // считываем символ новой строки '\n'
        counter++; // инкремент счётчика записей
    }
return 0;
}
Необходимо упорядочить записи структуры STUD по полю Name в алфавитном порядке и вывести результат на экран
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.10.2017, 22:24
Ответы с готовыми решениями:

Сортировка структуры по алфавиту
Доброго времени суток!Возник вопрос, как отсортировать структуру по алфавиту,пробовал сделать по примерам из других тем,но ничего не...

Сортировка по алфавиту структуры
Прошу помощи, так как уже просто несколько дней подряд никак не получается сделать лабу по программированию. Препод у нас не самый лучший,...

Сортировка Структуры по алфавиту
подскажите как сортировать фамилии по алфавиту? struct WORKER{ char lastnamepip; char posada; int year; }; ...

49
55 / 39 / 18
Регистрация: 21.05.2015
Сообщений: 184
11.11.2017, 13:50  [ТС]
Студворк — интернет-сервис помощи студентам
else убрал, инкремент вынес в конец цикла while. Работает правильно. Нужно только сделать сортировку для вывода значений второго while в порядке возрастания среднего балла. А также, чтобы в случае если все средние значения Middle < 4.2 (случай на скрине) выводило одно сообщение об отсутствии студентов (с else в прошлый раз нормально не получилось)
Миниатюры
Сортировка записей Структуры по алфавиту  
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
11.11.2017, 13:56
Ты же по именам хотел сортировать.
0
55 / 39 / 18
Регистрация: 21.05.2015
Сообщений: 184
11.11.2017, 13:58  [ТС]
Цитата Сообщение от nmcf Посмотреть сообщение
Ты же по именам хотел сортировать.
Сортировка по имени (алфавиту) работает отлично, но она нужна для вывода всех сообщений. Для второго раза (когда средний бал больше 4.2) нужно второй список отсортировать по возрастанию среднего балла
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
11.11.2017, 13:59
Ну добавь ещё одну сортировку, только условие замени на сравнение средних.
0
55 / 39 / 18
Регистрация: 21.05.2015
Сообщений: 184
11.11.2017, 14:04  [ТС]
Цитата Сообщение от nmcf Посмотреть сообщение
Ну добавь ещё одну сортировку, только условие замени на сравнение средних.
В старой сортировке нужно где-то это изменить? Если да, то где?
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
11.11.2017, 14:13
Ну в условии сделаешь return (средний a) < (средний b) вместо strcmp.
0
55 / 39 / 18
Регистрация: 21.05.2015
Сообщений: 184
11.11.2017, 14:17  [ТС]
Верно?
C++
1
sort(STUD1, STUD1 + STUD1_size,[] (const STUD & a, const STUD & b) {return Middle.a < Middle.b;});
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
11.11.2017, 15:23
Нет. Вместо Middle записывай всё выражение, по которому среднее вычисляется.
(a.SES[0] + a.SES[1] ...) / 4
И так же для b.
0
55 / 39 / 18
Регистрация: 21.05.2015
Сообщений: 184
11.11.2017, 20:11  [ТС]
Всё понял, всё сработало. А как быть с
C++
1
else cout << "Такого студента нет" << endl;
, в случае отсутствия средних баллов выше 4.2

Добавлено через 4 часа 25 минут
Не знаю даже куда эту строку вставить для верной работы
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
11.11.2017, 20:29
Используй дополнительный счётчик с инкрементом при выполнении условия. По завершении цикла проверишь - если ноль, то выведешь это сообщение.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
11.11.2017, 20:29

Сортировка структуры по алфавиту
Здравствуйте, написал прогу, но с сортировкой не получается, и извините, что там все криво-косо.В чем ошибка(и)? #include...

Структуры.Сортировка фамилий по алфавиту
Не могу отсортировать по фамилиям.Необходимо использовать функцию bool compare(){...},чтобы сравнить две фамилии.Как это сделать?Что нужно...

Сортировка записей по алфавиту
всем привет! подскажите плиз! у меня в файле есть записи (там фамилии людей) мне нужно сделать все отсортировать по алфавиту! и вывести на...

Сортировка структуры по алфавиту
Есть динамический массив структур, в нем лежат имя, фамилия, отчество и номер телефона. Нужно сделать сортировку по имени ( по алфавиту),...

Сортировка структуры слов по алфавиту
В структуре нам даны имена автора(или просто слова) и другие составляющие(название песни, жанр), необходимо отсортировать по алфавиту, но я...


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

Или воспользуйтесь поиском по форуму:
50
Ответ Создать тему
Новые блоги и статьи
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу))) Критические ошибки, мешающие компиляции и. . .
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата) Этот документ предназначен для того, чтобы новый чат Claude мог продолжить работу без необходимости заново разбираться в. . .
сукцессия 15 неявная схема
anaschu 29.06.2026
Алиса Калибровка параметров симбиотической модели: технический обзор Содержание: Введение Постановка проблемы Технические аспекты реализации Процесс внедрения изменений
сукцессия 14. Обновленная схема модели
anaschu 28.06.2026
ГЛОБАЛЬНАЯ ОПИСАТЕЛЬНАЯ СПЕЦИФИКАЦИЯ ЭКОСИСТЕМНОЙ МОДЕЛИ «SOIL CHEMISTRY & MYCORRHIZA 2. 0» https:/ / ibb. co/ NnkGpfMd Представленная интегрированная схема описывает непрерывную нелинейную. . .
сукцессия 13. Питон модель трехзонного мицелия, пока что в основном арбускулярного
anaschu 28.06.2026
## Разработка агентной модели микоризной сукцессии: от выявления артефактов к созданию комплексной системы ### Аннотация Представлено исследование по разработке агентной модели микоризной. . .
сукцессия 12. краткий список проверок модели перед запуском.
anaschu 27.06.2026
Скрытые отказы в моделях систем динамики (SD-models) экологических систем: два случая из практики Контекст Разбирался прототип модели систем динамики (SD-модели) микоризной сукцессии: пять. . .
Сукцессия 11. Проверка орудий перед войной: разработка через тестирование
anaschu 27.06.2026
Как не дать модели соврать самой себе: проверки для симуляции микоризной сукцессии Введение Когда вы строите математическую модель живой системы — грибов, растений, почвы — главная опасность. . .
10 сукцессия. Питон код войны грибов и растений
anaschu 27.06.2026
import numpy as np class PlantAgent: def __init__(self, name, strategy, initial_biomass): self. name = name self. strategy = strategy # "greedy" (широколиственные) или. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru