Форум программистов, компьютерный форум CyberForum.ru

Стек на базе массива - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.89
Demonhunterus
1 / 1 / 0
Регистрация: 20.09.2010
Сообщений: 36
25.09.2010, 15:12     Стек на базе массива #1
Есть код
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
#include <iostream>
#include <string>
 
using namespace std;
 
template <class T>
 
class STACK
{
private:
    T *s; int N;
public:
    STACK()
    {s=new T[5];N=0;}
    ~STACK(){}
    
    void push(T val)
    {
        s[N++]= val;
    }
    
    
    bool empty(){return (N == 0);}
    
    T pop()
    {
        return s[--N];
    }
};  
 
int main()
{
    STACK <string> s;
    int key;
    string val;
    do
    {
        system("cls");
        cout << "\tStack\t\t\t\n\n";
        cout << "1 - push\n";
        cout << "2 - pop & write\n";
        cout << "3 - exit\n\n";
        cout << "press key: ";
        cin >> key;
        switch (key)
        {
            case 1:
                {
                    cout << "\nenter element: ";
                    cin >> val;
                    s.push(val);
                    break;    
                }
            case 2:
                {
                    if (s.empty()) cout << "stack is empty..";
                    else
                    {
                        cout << "poping:\n";
                            cout << s.pop() << endl;
                    }
                    system("pause");
                    break;    
                }
            default:
                {
                    if (key == 3) cout << "exiting succesfully..\n";
                    else cout << "press only 1, 2 or 3\n";
                    system("pause");
            }                
        }
    }
    while (key != 3);
    
    return 0;
}
Вроде бы всё работет,всё отлично и красиво.Есть только вот одно "но".
C++
1
{s=new T[5];N=0;}
--- тут я задаю максимальное количество элементов в стеке = 5.Если в ходе работы программы попытаться запихнуть шестой элемент - программа вылетает.
Вопрос:
что прописать в
C++
1
2
3
4
5
6
7
case 1:
                {
                    cout << "\nenter element: ";
                    cin >> val;
                    s.push(val);
                    break;    
                }
,чтобы в случае,если стек полон,а мы попытаемся запихнуть в него на один элемент больше (как у меня - всего 5,а пытаемся задать шестой) программа не вылетала а писала "stack is full"?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.09.2010, 15:12     Стек на базе массива
Посмотрите здесь:

Стек на основе динамического массива C++
Динамическое программирование, стек на базе списка... C++
Стек на основе статического массива C++
Стек на базе статического массива C++
Создать базовый класс список. Реализовать на базе списка стек и очередь с виртуальными функциями вставки и вытаскивания C++
C++ Стек на основе массива
Стек в виде массива C++
Сформировать стек из массива C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
TheMachinist
 Аватар для TheMachinist
242 / 174 / 15
Регистрация: 14.06.2010
Сообщений: 422
25.09.2010, 15:23     Стек на базе массива #2
C++
1
2
3
4
5
6
7
8
9
10
11
int Push (T val)
{
if(N >= 5)
{
cout << "Stack is full.";
return 0;
}
s[N] = val;
N++;
return 0;
}
Я не проверял, но должно быть примерно так
Demonhunterus
1 / 1 / 0
Регистрация: 20.09.2010
Сообщений: 36
25.09.2010, 16:18  [ТС]     Стек на базе массива #3
Работает,спасибо ^_^
Yandex
Объявления
25.09.2010, 16:18     Стек на базе массива
Ответ Создать тему
Опции темы

Текущее время: 21:08. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru