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

Подправить стек - C++

Восстановить пароль Регистрация
 
 
tokar2
25 / 25 / 1
Регистрация: 09.11.2012
Сообщений: 229
17.11.2012, 22:27     Подправить стек #1
Что здесь не так? Помогите исправить ошибку, я уже 3 дня исправляю, и не могу додуматься в чем проблема!
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
#include<iostream>
#include<stdio.h>
#include<conio.h>
using namespace std;
const int maxlength = 100;
struct Stack
{
    int top;
    char elements[maxlength];
};
void MAKENULL(Stack *);
char TOP(Stack *);
void POP(Stack *);
void PUSH(char ch, Stack *);
bool EMPTY(Stack *);
void PRINT(Stack *);
 
int main()
{
    Stack S;
    int c;
    MAKENULL (&S);
    cin>>c;
    while(c != '=')
    {
        switch (c)
        {
        case 1:
            {
                POP(&S);
                break;
            }
        case 2:
            {
                MAKENULL(&S);
                break;
            }
        case 3:
            {
                PUSH(TOP(&S),&S);
                break;
            }
        default:
            {
                PUSH(c,&S);
                break;
            }
        }
        c = getchar();
    }
        PRINT(&S);
        getch();
        return 0;
}
char TOP(Stack *S)
{
  if (EMPTY(S) == true)
    printf("Stack is empty\n");
  else 
    return S->elements[S->top];
}
 
void MAKENULL(Stack *S)
{
  S->top = maxlength + 1;
}
 
void POP(Stack *S)
{
  if (EMPTY(S) == true)
    printf("Stack is empty\n");
  else 
    S->top = S->top + 1;
}
 
void PUSH(char ch, Stack *S)
{
  if (S->top == 0)
    printf("Stack is full\n");
  else 
  {
    S->top = S->top - 1;
    S->elements[S->top] = ch;
  }
}
  
bool EMPTY(Stack *S)
{
  if (S->top == maxlength)
    return true;
  else 
    return false;
}
 
void PRINT(Stack *S)
{
  for (int i = maxlength; i >= S->top; i--) 
  {
    putchar(S->elements[i]);
  }
  printf("\n");
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.11.2012, 12:04     Подправить стек
Еще ссылки по теме:

Структура стек (: добавить элемент в стек, удалить элемент из стека, получить значение с вершины стека, размер стека...) C++
подправить C++
Переменные в стеке. Где хранятся? Как обрабатываются? Есть ли программный стек или только стек процессора? C++

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

Или воспользуйтесь поиском по форуму:
tokar2
25 / 25 / 1
Регистрация: 09.11.2012
Сообщений: 229
18.11.2012, 12:04  [ТС]     Подправить стек #21
Peregrin, Спасибо за ваши старания, я бы сам еще долго сидел над этим!
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Yandex
Объявления
18.11.2012, 12:04     Подправить стек
Ответ Создать тему
Опции темы

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