0 / 0 / 0
Регистрация: 29.04.2017
Сообщений: 1
1

Стеки. Удаление между минимальным и максимальным

29.04.2017, 13:50. Показов 4805. Ответов 0

Author24 — интернет-сервис помощи студентам
Нужна помощь с заданием. В созданном списке определить количество и удалить все элементы, находящиеся между минимальным и максимальным элементами. Я смог найти значения, но как удалить вообще без понятия.(Функция Del_5)
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
#include <vcl.h>
#pragma hdrstop
#include <iostream.h>
#include <conio.h>
 
 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;
}
 
Stack* OutStack (Stack *p, int *out)   {
        Stack *t = p;
        *out = p -> info;
        p = p -> next;
        delete t;
        return p;
}
 
 
void View(Stack *p) {
        Stack *t = p;
        while( t != NULL) {
        cout << "   " << t->info << endl;
                t = t -> next;
        }
}
 
void Del_All(Stack **p) {
        while(*p != NULL) {
                t = *p;
                *p = (*p) -> next;
                delete t;
        }
}
 
Stack* Del_5(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;
}
 
 
 
 
 
void main()
{
    int i, in, n, kod;
while(true){
   cout << "\n\tCreat - 1.\n\tAdd - 2.\n\tView - 3.\n\tDel - 4.\n\tDo sort - 5.\n\tEXIT – 0.  :  " ;
   cin >> kod;
   switch(kod) {
      case 1: case 2:
            if(kod == 1 && begin != NULL){
                            cout << "Clear Memory!" << endl;
                            break;
                }
         cout << "Input kol = ";         cin >> n;
         for(i = 1; i <= n; i++)  {
                in = random(20);
                begin = InStack(begin, in);
         }
         if (kod == 1) cout << "Create " << n << endl;
         else cout << "Add " << n << endl;
      break;
      case 3:         if(!begin){
                        cout << "Stack Pyst!" << endl;
                        break;
                     }
         cout << "--- Stack ---" << endl;
         View(begin);
      break;
      case 4:
         Del_All(&begin);
         cout<<"Memory Free!"<<endl;
      break;
      case 5:
         begin = Del_5 (begin);
         break;
      case 0:
         if(begin != NULL)
            Del_All(&begin);
         return;        
}
 
     }
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
29.04.2017, 13:50
Ответы с готовыми решениями:

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

Найти сумму членов последовательности, расположенных между максимальным и минимальным значением
Доброе время суток! Самостоятельно изучаю C++. Нашел интересную задачу. Что-то запутался и не могу...

Нужно удалить элементы находящиеся между максимальным и минимальным элементом стека
В принципе, нужна часть кода, а именно удаление элементов, т.к. со стеками работаю в первый раз, ...

Найти сумму элементов массива, находящихся между его максимальным и минимальным элементами
Как найти суму элементов масива что находятся между максимальным и минимальным элементом масива, в...

0
29.04.2017, 13:50
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
29.04.2017, 13:50
Помогаю со студенческими работами здесь

Произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами
Здравствуйте, помогите мне пожалуйста реализовать данный пример. Произведение элементов массива,...

Поменять в Мемо местами строки с максимальным и минимальным значением
При нажатии на кнопку1 выводится некоторое количество псевдослучайных чисел void __fastcall...

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

Произведение между минимальным и максимальным
#include &lt;iostream&gt; #include&lt;random&gt; #include&lt;time.h&gt; using namespace std; int main() {...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru