Larica
1

Развернуть стек

20.11.2013, 13:45. Показов 3244. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Развернуть стек, т.е. сделать "дно" стека вершиной, а вершину - "дном". Стек должен быть на основе массива.
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
20.11.2013, 13:45
Ответы с готовыми решениями:

Как развернуть стек?
Как вывести элементы из стека в порядке их поступления? через функцию не получается #include...

Используя стек, описать функцию проверяющую, является ли стек пустым
Используя стек, описать функцию проверяющую, является ли стек пустым

Программа добавляет введенный массив 5*5 в стек и выводит полученный стек двумя столбцами
Программа добавляет введенный массив 5*5 в стек и выводит полученный стек двумя столбцами ...

Заполнить стек 20 случайными числами с интервала [0; -10]. Вывести стек на экран. Изъять из стека каждый четвертый элеме
Заполнить стек 20 случайными числами с интервала . Вывести стек на экран. Изъять из стека каждый...

2
4 / 4 / 1
Регистрация: 22.10.2013
Сообщений: 34
20.11.2013, 13:53 2
Лучший ответ Сообщение было отмечено как решение

Решение

Это стек с нормальными вершинами, дальше додумайте сами.
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
#ifndef STACK_
#define STACK_
struct customer
{
    char Fullname[35];
    double Payment; 
};
typedef customer Item;
static double Subtotal = 0;
class Stack
{
    static const int MAX = 10;  
    Item Items [MAX];           //хранит элементы стека
    int Top;                    //индекс вершины стека
public:
    Stack();
    bool isempty() const;
    bool isfull() const;
    bool push(const Item & item);       //добавляет элементы в стек
    bool pop(Item & item);              //выталкивает элемент с вершины стека    
};
#endif
 
 
 
#include "stdafx.h"
#include "stack.h"
#include <iostream>
 
Stack :: Stack()
{
    Top = 0;
}
bool Stack :: isempty() const
{
    return Top == 0;
}
bool Stack :: isfull() const
{
    return Top == MAX;
}
bool Stack :: push(const Item & item)
{
    if (Top < MAX)
    {
        Items[Top++]= item;
        return true;
    }
    else 
        return false;
}
bool Stack :: pop(Item & item)
{
    if (Top > 0)
    {
        item = Items[--Top];
        Subtotal += item.Payment;
        std::cout<<"Subtotal = "<<Subtotal<<'\n';
        return true;
    }
    else 
        return false;
}
0
Заблокирован
20.11.2013, 13:54 3
C++
1
2
3
4
5
6
7
std::vector<int> stack;
stack.push_back(3);
stack.push_back(5);
stack.push_back(66);
stack.push_back(-23);
stack.push_back(45);
std::reverse(stack.begin(), stack.end());
0
20.11.2013, 13:54
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
20.11.2013, 13:54
Помогаю со студенческими работами здесь

Переменные в стеке. Где хранятся? Как обрабатываются? Есть ли программный стек или только стек процессора?
Есть у меня пробелы в познаниях, хотел бы их устранить. 1. Что такое стек в самом языке С++ ? 2....

Сформировать стек из 6 цифр. Вывести стек на экран. Удалить элементы из стека, увеличить каждый из них на единицу и снов
Сформировать стек из 6 цифр. Вывести стек на экран. Удалить элементы из стека, увеличить каждый из...

Сформировать стек из N чисел. Найти сумму нечетных чисел из стека. Результат поместить в стек
Здравствуйте. Помогите, пожалуйста, решить задачу: Сформировать стек из N чисел. Найти сумму ...

при работе рекурсивной функции заканчивается стек и программа соответственно; как сделать так, чтобы она писала "стек закончился"?
Сабж g++ 4.5.0


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

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

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