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

Как в стеке найти масимальный и минимальный элемент и удалить между ними цифры

20.03.2018, 21:33. Показов 2291. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В функции void sort_p

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
#include "stdafx.h"
#include <stack> 
#include <iostream>
#include <cstdio>
#include <cstdint>
 
struct Stack {
    int info;
    Stack *next;
} *begin, *t;
 
Stack* InStack(Stack *p, int in) {
    Stack *t = new Stack; 
    t->info = in; 
    t->next = p; 
    return t;
}
 
void View(Stack *p) {
    Stack *t = p;
    while (t != NULL) {
       printf_s("%d ", t->info);
        t = t->next;
    }
}
 
Stack* OutStack(Stack* p, int *out) {
    Stack *t = p;    // Устанавливаем указатель t на вершину p
    *out = p->info;
    p = p->next;     // Переставляем вершину p на следующий
    delete t;        // Удаляем бывшую вершину t
    return p;        // Возвращаем новую вершину p
}
 
void Del_All(Stack **p) {    //освобождение памяти
    Stack *t;
    while (*p != NULL) {
        t = *p;
        *p = (*p)->next;
        delete t;
    }
}
 
void Sort_p(Stack **p) {
    int min = begin->info;
    Stack *s;
    for (s = begin; s != NULL; s = s->next)
    {
        if (s->info < min) {
            min = s->info;
        }
       int max=begin->info;
       for (s = begin; s != NULL; s = s->next)
    {
        if (s->info > max) {
            max = s->info;
        }
    }
}
 
 
int main()
{
    setlocale(LC_ALL, "rus");
    int a, i, n, in, kod;
    while (true) {
        puts("\n Создать – 1\n Добавить – 2\n Просмотреть – 3\n Удаляем - 4\n Решение - 5\n Выход - 0\n ");
        scanf_s("%d", &kod);
        switch (kod) {
        case 1: case 2:
            if (kod == 1 && begin != NULL) {
                puts("\nClear Memory!\n");
                break;
            }
            puts("\n Количество = ");
            scanf_s("%d", &n);
            for (i = 1; i <= n; i++) {
                in = rand() % 20 + 0;
                begin = InStack(begin, in);
            }
            if (kod == 1) {
                puts("Создаем");
                scanf_s("%d", &n);
            }
            else {
                puts("Добавляем");
                scanf_s("%d", &n);
            }
            break;
        case 3:
            if (!begin) {
                puts("\n\t---Стек пуст---\n");
                break;
            }
            puts("---Стек---");
            View(begin);
            break;
        case 4:
            Del_All(&begin);
            puts("\t---Память очищена---");
            break;
            case 5:
                Sort_p(&begin);
                break;
            case 0:
                if (begin != NULL)
                    Del_All(&begin);
                break;
        }
    }
        return 0;
    
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.03.2018, 21:33
Ответы с готовыми решениями:

Создать таблицу и найти в ней минимальный элемент, затем найти второй минимальный элемент и узнать расстояние между ними
Например у нас есть таблица Минимальным элементом является 1, а следующим минимальным элементом является 4. Между ними расстояние 3. Я...

Найти максимальный и минимальный элемент последовательности и произведение чисел, расположенных между ними
Здравствуйте. Я предпринял попытку решения задачи &quot;Домашнее задание&quot;. Проблема в том, что на некоторых тестах программа выводит...

Найти минимальный элемент в стеке и вставить после него 0
Необходимо найти минимальный элемент в стеке и вставить после него 0.

5
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
21.03.2018, 10:12
Стек не предназначен для того, чтобы в нём "ковырялись посередине". Ваша задача по честному может решаться только с помощью перетасовывания данных из стека - в стек с использованием промежуточного хранилища данных.
0
 Аватар для palva
4272 / 2966 / 691
Регистрация: 08.06.2007
Сообщений: 9,915
Записей в блоге: 4
21.03.2018, 10:35
Вам поручили реализовать стек самому? А что использовать стек из библиотеки STL нельзя?
То что у вас так странно реализовано это однонаправленный список. Наверно, его можно использовать как стек. Но единственное, что можно делать со стеком это положить число на вершину и взять число с вершины. Ну и получить информацию о том что стек пуст.
0
0 / 0 / 0
Регистрация: 29.11.2017
Сообщений: 87
21.03.2018, 15:54  [ТС]
а как тогда просто переместить в другой стек?
0
 Аватар для palva
4272 / 2966 / 691
Регистрация: 08.06.2007
Сообщений: 9,915
Записей в блоге: 4
21.03.2018, 16:07
Цитата Сообщение от Pelmesh_ Посмотреть сообщение
а как тогда просто переместить в другой стек?
Просто переместить непонятно что нельзя. Я же написал, что можно делать со стеком.
И еще. У вас должен быть реализован стек. Вы либо реализуете его сами, либо используете STL.
0
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
21.03.2018, 21:12
Pelmesh_,
Цитата Сообщение от MrGluck Посмотреть сообщение
Стек не предназначен для того, чтобы в нём "ковырялись посередине". Ваша задача по честному может решаться только с помощью перетасовывания данных из стека - в стек с использованием промежуточного хранилища данных.
Рекурсия - наше всё. Все данные при использовании рекурсии будут на стеке, так что условие соблюдается, и не надо самому писать или реализовывать дополнительный стек
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.03.2018, 21:12
Помогаю со студенческими работами здесь

(с#) Найти минимальный элемент в стеке и вставить перед ним 0.
Необходимо найти минимальный элемент в стеке и вставить ноль перед ним. Вот как получилось организовать программу,но искать минимальным мы...

Найти в стеке минимальный элемент и вставить после него 0
Найти минимальный элемент и вставить после него 0.

Найти в стеке самый максимальный элемент и удалить его
Доброго времени суток. У меня, к примеру, есть стек. В нем введено несколько элементов, допустим 4. Как найти в стеке самый максимальный и...

Найти масимальный и минимальный элементы матрицы и поменять их местами
Дан двумерный массив размерностью NxM (N и M дятся с клавиатуры). Найти масимальный и минимальный элементы данного массива и поменять их...

В матрице найти минимальный, максимальный элементы и произведение между ними
Составить программу, которая находит в каждой строке матрицы Q(k,l), k&lt;=12, l&lt;=14 произведение элементов, расположенных между минимальным и...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 05.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 17.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru