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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Строки http://www.cyberforum.ru/cpp-beginners/thread209810.html
Здравствуйте!надо написать метод к основной программе! Очень прошу помочь!сегодня сдать через три часа! Вот собственно сам вопрос: procedure Replace (Source: String; var S: String; Index: Integer); Заменяет символы строки S, начиная с позиции Index, на символы строки Source.
C++ Бесконечное суммирование Получил задание по бесконечному суммированию но не как не могу разобраться как же это делается. Вот то что нам дал препод чтобы разобраться в выполнении задания(во вложении объяснение выполнения но я не въехал) Задание: написать функцию которая для заданного аргумента x и заданной точности e вычисляет значение функции Y(x)=F(x)=x-(x^3)/(3^2)+(x^5)/(5^2)-(x^7)/(7^2)... как сумму членов... http://www.cyberforum.ru/cpp-beginners/thread209803.html
Массивы C++
1) Найти последний нулевой элемент массива, заменить его индексом и поставить перед 5 элементом 2) Из массива удалить положительные элементы, превышающие заданную величину 3) Напечатать первое слово, содержащее два подряд заданных символа, и возратить адрес его начала
C++ Структуры
вот написал прогу но почему-то она не работает ))))) проверьте пожалуйста второй день мучаюсь с ней!!! заране благадарен // дз на структуры.cpp: определяет точку входа для консольного приложения. // #include "stdafx.h" #include <stdio.h> #include <conio.h> #include <string.h> #include <locale.h>
C++ РАБОТА СО СТРУКТУРАМИ http://www.cyberforum.ru/cpp-beginners/thread209791.html
Судоходные реки: Название реки, протяженность, минимальная глубина фарватера. Дополнить вывод информацией о том, подходит ли река для судоходства большегрузных судов (минимальная глубина должна быть больше 4 м.)
C++ SOS Cpp Прижало меня, братцы, по полной.. завал жуткий, нужна ваша помощь, о великие гуру Срр!! Высылаю с этой депешей собственно задание и исходничек, к сожалению не правильный aka нерабочий, буду бесконечно признателен исправившему!! подробнее

Показать сообщение отдельно
Public
0 / 0 / 0
Регистрация: 13.12.2010
Сообщений: 22
13.12.2010, 11:43     Обратная польская запись
Доброго времени суток. В общем столкнулся с такой проблемой, пытаюсь реализовать алгоритм обратной польской записи, но не получается, проблема в том, что у меня цикл не доходит до проверки приоритетов.
Собственно даже не знаю, в чем могут быть проблемы. Подскажите, может кто уже писал, и сталкивался с этим же.
вот код:

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;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 03:37. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru