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

Реализовать функцию сортировки стека

22.02.2022, 19:52. Показов 821. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Помогите дописать функцию сортировки:
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
#include <iostream>
#include <string>
#include <algorithm>
#include <Windows.h>
#include <conio.h>
 
struct Node
{
    char data[50];
    Node* next;
};
 
typedef Node* PNode;
 
void sort(PNode);
void see(PNode);
PNode butld(PNode);
PNode add(PNode);
PNode del(PNode);
 
int main()
{
    setlocale(LC_ALL, "");
    Node* s;
    s = NULL;
    while (1) {
        std::cout << "===================================================" << std::endl;
        std::cout << "Вид операции:                 A - создать/добавить;" << std::endl;
        std::cout << "                              D - удалить;" << std::endl;
        std::cout << "                              S - просмотреть;" << std::endl;
        std::cout << "                              C - сортировка;" << std::endl;
        std::cout << "                              E - закончить." << std::endl;
        std::cout << "===================================================" << std::endl;
 
        fflush(stdin);
        switch (_getch()) {
        case 'a': case 'A': case 'ф': case 'Ф': s = add(s); break;
        case 'd': case 'D': case 'в': case 'В': s = del(s); break;
        case 's': case 'S': case 'ы': case 'Ы': see(s); break;
        case 'e': case 'E': case 'у': case 'У': return 0;
        case 'c': case 'C': sort(s); break;
 
        default: std::cout << "Ошибка, повторите ввод." << std::endl;
            break;
        }
    }
    return 0;
}
 
PNode add(PNode s) {
    PNode s1;
    s1 = s;
    s = new Node;
    if (s == NULL) {
        std::cout << "Нет свободной памяти!" << std::endl;
        return 0;
    }
    std::cout << "Введите информацию в Data: ";
    std::cin >> s->data;
    s->next = s1;
    return s;
}
 
void see(PNode s) {
    PNode s1;
    s1 = s;
    if (s == NULL) {
        std::cout << "Стек не создан." << std::endl;
        return;
    }
 
    do {
        std::cout << s1->data << std::endl;
        s1 = s1->next;
    } while (s1 != NULL);
    std::cout << "Вывод стека закончен." << std::endl;
}
 
PNode del(PNode s) {
    PNode s1;
    if (s == NULL) {
        std::cout << "Стек пуст." << std::endl;
        return 0;
    }
    s1 = s;
    s = s->next;
    delete(s1);
    std::cout << "Последний элемент стека удален." << std::endl;
    return (s);
}
 
void sort(PNode s) {
    PNode s1;
    s1 = s;
    if (s == NULL) {
        std::cout << "Стек не создан." << std::endl;
        return;
    }
 
//реализовать сортировку здесь
 
    do {
        std::cout << s1->data << std::endl;
        s1 = s1->next;
    } while (s1 != NULL);
 
    std::cout << "Вывод отсортированного стека закончен." << std::endl;
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.02.2022, 19:52
Ответы с готовыми решениями:

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

Напишите функцию сортировки, похожую на функцию которая использовалась для сортировки массивов, с той разницей, что ее а
Напишите функцию сортировки, похожую на функцию которая использовалась для сортировки массивов, с той разницей, что ее аргументом должен...

Реализовать функцию нахождения двух крайних положительных чисел и сортировки массива согласно условию
Доброе время суток! Подскажите, как функцией сделать следующее.... Функция находит два крайних положительных числа и сортирует массив...

2
0 / 0 / 0
Регистрация: 14.04.2020
Сообщений: 6
03.03.2022, 19:40  [ТС] 2
Есть предположения?
0
 Аватар для igorrr37
2866 / 2014 / 990
Регистрация: 21.12.2010
Сообщений: 3,720
Записей в блоге: 15
04.03.2022, 08:09 3
Лучший ответ Сообщение было отмечено Awoke как решение

Решение

пузырьком
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
#include <iostream>
#include <string>
#include <algorithm>
#include <cstring>
#include <Windows.h>
#include <conio.h>
 
struct Node
{
    char data[50];
    Node* next{};
};
 
typedef Node* PNode;
 
void sort(PNode);
void see(PNode);
PNode butld(PNode);
PNode add(PNode);
PNode del(PNode);
 
int main()
{
    setlocale(LC_ALL, "");
    Node* s;
    s = NULL;
    while (1) {
        //system("cls");
        std::cout << "===================================================" << std::endl;
        std::cout << "Вид операции:                 A - создать/добавить;" << std::endl;
        std::cout << "                              D - удалить;" << std::endl;
        std::cout << "                              S - просмотреть;" << std::endl;
        std::cout << "                              C - сортировка;" << std::endl;
        std::cout << "                              E - закончить." << std::endl;
        std::cout << "===================================================" << std::endl;
 
        fflush(stdin);
        switch (_getch()) {
        case 'a': case 'A': case 'ф': case 'Ф': s = add(s); break;
        case 'd': case 'D': case 'в': case 'В': s = del(s); break;
        case 's': case 'S': case 'ы': case 'Ы': see(s); break;
        case 'e': case 'E': case 'у': case 'У': return 0;
        case 'c': case 'C': sort(s); break;
 
        default: std::cout << "Ошибка, повторите ввод." << std::endl;
            break;
        }
    }
    return 0;
}
 
PNode add(PNode s) {
    PNode s1;
    s1 = s;
    s = new Node;
    if (s == NULL) {
        std::cout << "Нет свободной памяти!" << std::endl;
        return 0;
    }
    std::cout << "Введите информацию в Data: ";
    std::cin >> s->data;
    s->next = s1;
    return s;
}
 
void see(PNode s) {
    PNode s1;
    s1 = s;
    if (s == NULL) {
        std::cout << "Стек не создан." << std::endl;
        return;
    }
 
    do {
        std::cout << s1->data << std::endl;
        s1 = s1->next;
    } while (s1 != NULL);
    std::cout << "Вывод стека закончен." << std::endl;
}
 
PNode del(PNode s) {
    PNode s1;
    if (s == NULL) {
        std::cout << "Стек пуст." << std::endl;
        return 0;
    }
    s1 = s;
    s = s->next;
    delete(s1);
    std::cout << "Последний элемент стека удален." << std::endl;
    return (s);
}
 
void sort(PNode s) {
    PNode s1 = s;
    if (s == NULL) {
        std::cout << "Стек не создан." << std::endl;
        return;
    }
    //реализовать сортировку здесь
    bool swap = true;
    while (swap)
    {
        swap = false;
        s = s1;
        while (s->next)
        {
            if (strcmp(s->data, s->next->data) > 0)
            {
                std::swap(s->data, s->next->data);
                swap = true;
            }
            s = s->next;
        }
    }
 
    do {
        std::cout << s1->data << std::endl;
        s1 = s1->next;
    } while (s1 != NULL);
 
    std::cout << "Вывод отсортированного стека закончен." << std::endl;
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.03.2022, 08:09
Помогаю со студенческими работами здесь

Реализовать функцию нахождения двух крайних отрицательных чисел и сортировки массива согласно условию
Доброе время суток! Подскажите, как функцией сделать следующее.... Функция находит два крайних отрицательных числа и сортирует массив...

Алгоритм сортировки стека с ограниченными условиями
Друзья! Помогите с алгоритмом. Суть следующая: Есть 2 стека. В первом записано N int элементов, второй стек - пуст. Задача -...

Переполнение стека в рекурсивной функции сортировки большого массива
Написал рекурсивную функцию сортировки массива, с массивами небольших размеров все работает как надо, а вот если сортирую побоьлше (60000...

Реализовать переполнение стека
Помогите пожалуйста: Задали написать программу, где будет переполнение стека ( если съедает оперативной памяти больше, чем я выделил, то...

не могу разобраться как написать функцию сортировки и исправить функцию добавления в стек
#include &lt;iostream&gt; #include&lt;Windows.h&gt; using namespace std; struct NE{ int x; NE *pnext,*ppor,*cur;}; class SPISOK { NE...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Новые блоги и статьи
Создание и использование компонентов в Vue 3
Reangularity 14.03.2025
Компонент в Vue - это автономный блок интерфейса, который содержит собственную разметку, логику и стили. Представьте себе кнопку, форму ввода или даже целую панель навигации - всё это можно оформить. . .
Vue 3: Создаем современное веб-приложение с Composition API
Reangularity 14.03.2025
В фронтенд-разработке Vue 3 выделяется своим прагматичным подходом. В отличие от React с его минималистичной философией "всё — JavaScript" или Angular с его всеобъемлющим корпоративным подходом, Vue. . .
Разработка контекстных меню в iOS
mobDevWorks 14.03.2025
С приходом iOS 13 Apple представила новый API для контекстных меню, который полностью заменил предыдущую технологию 3D Touch peek & pop. Хотя многие разработчики и пользователи испытывают ностальгию. . .
Лучшие практики оптимизации Docker Image
Mr. Docker 13.03.2025
Размер Docker-образа влияет на множество аспектов работы с контейнерами. Чем больше образ, тем дольше его загрузка в реестр и выгрузка из него. Для команд разработки, работающих с CI/ CD пайплайнами,. . .
Вопросы на собеседовании по Docker
Mr. Docker 13.03.2025
Ты сидишь напротив технического специалиста, и вдруг звучит вопрос про Docker Swarm или многоэтапные сборки. Пот на лбу? Не переживай, после этой статьи ты будешь готов ко всему! Эта статья будет. . .
Поиск текста в сносках : замена дефиса на тире или тире на дефис...
РоΜа 13.03.2025
Нужно было найти текст в сносках и заменить. Почему-то метод селекшн не сработал. . . пришлось гуглить. найденный на форумвба код пришлось править. Смысл - заменяет в сносках дефисы и тире на нужные. . . .
Real PATH definitions in bash scripts
jigi33 13.03.2025
Как поймать путь и путь к директории относительно запускаемого файла в BASH 1. поймать путь через вывод $(pwd) 2. более правильно - на основе realpath (см. скриншот)
Django или Flask: что выбрать для веб-разработки на Python
py-thonny 13.03.2025
Django – это высокоуровневый фреймворк, который придерживается философии "всё включено". Он предоставляет разработчику готовые решения для большинства типичных задач веб-разработки: от аутентификации. . .
Непрерывное развертывание в Java с Kubernetes
Javaican 13.03.2025
Чем так привлекателен Kubernetes для развертывания Java-приложений? Этот оркестратор контейнеров позволяет автоматизировать развертывание, масштабирование и управление контейнеризированными. . .
Предотвращение XSS, CSRF и SQL-инъекций в JavaScript
run.dev 13.03.2025
JavaScript занимает первые позиции среди языков веб-разработки, но его распространенность делает его привлекательной целью для злоумышленников. Межсайтовый скриптинг (XSS), межсайтовая подделка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер