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

Не могу реализовать сортировку по алфавиту

10.12.2022, 23:01. Показов 351. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер. Я уже писал сюда, но у меня осталась прям жестокая проблема, с которой я уже 2 день не могу разобраться.
Так вот, задание следующее:

Определить класс с именем NОТЕ, содержащий следующие поля:
● фамилия, имя;
● номер телефона;
● день рождения (массив из трех чисел).
Определить методы доступа к этим полям и перегруженные операции
извлечения и вставки для объектов типа NОТЕ.
Заранее число объектов не известно.
Написать программу, выполняющую следующие действия:
● записи должны быть размещены по алфавиту;
● вывод на экран информации о людях, чьи дни рождения приходятся
на месяц, значение которого введено с клавиатуры;
● если таких нет, выдать на дисплей соответствующее сообщение.

Я сделал всё, но у меня осталась крупная проблема: я не могу нормально реализовать сортировку по алфавиту. Мне удалось что-то сделать, но это просто гоняет элементы как на колесе. Я уже не знаю, что делать.

Вот код этой функции, которую надо сделать (точнее, то, что я сделал, но не доделал до конца, она в Keeper.cpp):
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
void keeper::sort(int mode)
{
    int det = 1;
    int i = 0;
    place* p = head;
    place* p1 = nullptr;
    if (p->next == nullptr) { int er = 1; throw er; }
    unsigned prev = 0;
    bool exit = true;
    mode = (!mode) ? -1 : 1;// mode = 0 - сорт по возрастанию, 1 - по убыванию
 
    while (p->next != nullptr)
    {
        p->ntp->alphabete(i);
        p = p->next;
    }
    while (exit)
    {
        p = head;
        p1 = head->next;
        int j = 1;
        while (p1->next != nullptr)
        {
            for (i = 0; i < AUXSTRLEN; i++)
            {
                if ((-1 * mode * p->ntp->alphabete(i)) < (-1 * mode * p1->ntp->alphabete(i)))
                {
                    det = 0;
                    break;
                }
            }
            if (det == 0)
            {
                //Обмен
                copy(j + 1, j);
                del(j + 2);
                exit = false;
                j++;
                p = (*this)[j];
                p1 = (*this)[j + 1];
            }
        }
    }
}
Все части кода я приложил как вложение в виде архива, ибо ограничение символов не пропускает:
Файлы кода.zip
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.12.2022, 23:01
Ответы с готовыми решениями:

Описать структуру с именем NOTE и реализовать сортировку записей по алфавиту
Здравствуйте, вот помогите с кодом, программа работает, но не хватает сортировки по алфавиту, как исправить это? /* Описать...

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

Подскажите как эту сортировку переделать в сортировку по алфавиту?
Подскажите как эту сортировку переделать в сортировку по алфавиту?? vector&lt;std::pair&lt;string, int&gt;&gt; popularAuthor; ...

1
0 / 0 / 0
Регистрация: 27.09.2021
Сообщений: 59
10.12.2022, 23:01  [ТС]
Очень надеюсь на помощь, ибо уже опустились руки.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.12.2022, 23:01
Помогаю со студенческими работами здесь

Реализовать сортировку массива пузырьком, сортировку выбором и сортировку вставками
Вообщем в файле задан некий массив,так вот нужно провести сортировку пузырьком,сортировку выбором и сортировку вставками этого массива. ...

Реализовать сортировку расчёской и сортировку Шелла, не получается найти пример кода
Реализовать сортировку расчёской и сортировку Шелла, не получается найти пример кода или принцип работы алгоритма этих сортировок,...

Реализовать быструю сортировку или сортировку слиянием
Полуфиналы ограничение по времени на тест1 секунда ограничение по памяти на тест256 мегабайт вводстандартный ввод выводстандартный...

как сделать сортировку по алфавиту?
у меня есть база в MSSQL, я ее подключила к C#. в общем теперь мне нужно сделать сортировку данных в таблице по алфавиту. помогите...

Добавьте сортировку по алфавиту товара
Добавьте сортировку по алфавиту товара using System; using System.Collections.Generic; using System.Linq; using System.Text; ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru