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

Обратная польская запись - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.70
Public
0 / 0 / 0
Регистрация: 13.12.2010
Сообщений: 22
13.12.2010, 11:43     Обратная польская запись #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
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
// pol2.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include "string"
#include "iostream"
using namespace std;
    char InputStr[256],OutputStr[256],S[256];
    int i=0,R,Top;
    char T,N;
    //Функция, возвращающая следующий символ входжно строки
        char NextChar(){
            N=InputStr[i];
            return N;
        }
        //Функцкия определющая ранг
        int Rang(char x){
            int Rang=0;
                if(x!='+'||x!='-'||x!='*'||x!='/'){
                    Rang=1;
                }else{
                    Rang=-1;
                }
            return Rang; 
        }
        //Функция определяющая приоритет
        int Pr(char x){
            int Prior=0;
                if(x=='+'||x=='-'){
                    Prior=1;
                }else{
                    if(x=='*'||x=='/'){
                        Prior=2;
                    }else{
                        if(x!='#'){Prior=3;}else{Prior=0;}
                    }
                }
                return Prior;
        
        }
    void Pol(){
        Top=0;
        S[Top]='#';
            R=0;
            i=0;
                N=NextChar();
                cout<<"\n ololo : "<<Pr(N)<<"= "<<N<<" s[top]= "<<Pr(S[Top]);
                if(N=='#'){
                    cout<<"\n ####### ";
                    }
                cout<<"\n S[Top]= "<<S[Top];
                cout<<"\n Pr(N)= "<<Pr(N)<<"  Pr(S[TOP])= "<<Pr(S[Top]);
                while(N!='#'){
                        while(Pr(N)<=Pr(S[Top])){
                            cout<<"\n 1:";
                                i++;
                                cout<<"\n i= "<<i;
                                T=S[Top];
                                cout<<"\n T= "<<T;
                                Top--;
                                cout<<"\n Top "<<Top;
                                OutputStr[i]=T;
                                R=R+Rang(T);
                                cout<<"\n R "<<R;
                                    if(R<1){
                                            cout<<"\n ERROR ";
                                            cout<<"\n ";
                                            system("pause");
                                            break;
                                    }else{
                                        Top++;
                                        cout<<"\n Top1 "<<Top;
                                        S[Top]=N;
                                        cout<<"\n S[Top]= "<<S[Top];
                                        N=NextChar();
                                        cout<<"\n N= "<<N;
                                    }
                        }
                }
                while(S[Top]!='#'){
                        i++;
                        T=S[Top];
                        cout<<"\n T= "<<T;
                        Top--;
                        OutputStr[i]=T;
                        R=R+Rang(T);
                        if(R<1||R!=1){
                            cout<<"\n MISTAKE ";
                            cout<<"\n ";
                            system("pause");
                            break ;
                        }
                }
                cout<<"\n result: "<<OutputStr;
    }
 
 
    
int _tmain(int argc, _TCHAR* argv[])
{
    cout<<"\n INSERT STRING : ";
    cin>>InputStr;
    Pol();
    system("pause");
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
13.12.2010, 11:43     Обратная польская запись
Посмотрите здесь:

обратная польская запись. C++
Обратная польская запись C++
Обратная польская запись C++
Обратная польская запись C++
C++ Калькулятор (обратная польская запись)
C++ Обратная польская запись
C++ Обратная Польская Запись
Калькулятор: обратная польская запись C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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