Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.87/15: Рейтинг темы: голосов - 15, средняя оценка - 4.87
1 / 1 / 1
Регистрация: 09.04.2014
Сообщений: 71

Перевод из инфиксной в постфиксную запись

14.02.2015, 07:16. Показов 3217. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Суть моей программы: перевод из инфиксной в постфиксную запись.
Но проблема в том, что функция типа string не возвращает значение. В чём ошибка?
Main.cpp
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
#include<iostream>
#include<string>
#include<conio.h>
#include<cstdlib>
 
#include"ClassStack.h"
 
using namespace std;
 
 
 
int PrioritySign(char w)
{
    switch(w)
    {   
        case '^':
            return 4;
        case '/':
        case '*':
            return 3;
        case '+':
        case '-':
            return 2;
        case '(':
            return 1;       
    }
}
 
void InficsToPostfics(string &Str)
{
    Stack Stc;
    string OutStr;
       for(int i = 0; i < Str.size(); i++)
       {
           if(Str[i] == '(')
              Stc.AddHead(Str[i]);
           if(Str[i] == ')')
           { 
              while(Stc.Head != 0)
              {
                 if(Stc.Head->Text == '(')
                 {
                    Stc.DeleteHead();
                    break;
                 }
                 OutStr += Stc.Head->Text;
                 Stc.DeleteHead();  
              } 
           }  
           if((Str[i] == '*')||(Str[i] == '-')||(Str[i] == '+')||(Str[i] == '/')||(Str[i] == '^'))
           {
              if(Stc.Head == NULL)
                 Stc.AddHead(Str[i]);
              else
              {  
                 while((Stc.Head != NULL)&&(PrioritySign(Stc.Head->Text) > PrioritySign(Str[i])))
                 {
                    OutStr += Stc.Head->Text;
                    Stc.DeleteHead();
                 }
                 Stc.AddHead(Str[i]);
              }
           }
           else
           {
              OutStr += Str[i];
           }
       }
     while(Stc.Head != 0)
     {
        OutStr += Stc.Head->Text;
        Stc.DeleteHead();
     }  
     delete(&Stc);
     Str=OutStr;       
}
 
int main()
{
    string Str;
    cout << "Enter string" << endl;
    cin >> Str;
    InficsToPostfics(Str);
    cout << Str;
    getch();
    return 0;
}
ClassStack.h
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#ifndef STACK
#define STACK
 
 
struct List
{
    public:char Text;
    List *Next;
    List(char T):Next(NULL),Text(T){}
};
 
class Stack
{
   public:
   List *Head;
   void DeleteHead();
   void AddHead(char);
   friend int PrioritySign(char );
};
 
 
#endif
FuncStack.cpp

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include<iostream>
 
#include"ClassStack.h"
 
using namespace std;
 
 
 
void Stack::AddHead(char Text)
{
   List* newHead = new List(Text);
   newHead->Next = Head;
   Head = newHead; 
}
 
void Stack::DeleteHead()
{
     List *newHead = Head;
     Head = Head->Next;
     delete(newHead);
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.02.2015, 07:16
Ответы с готовыми решениями:

Из инфиксной в постфиксную
Привет, опять я с этим заданием. Уже глаз болит, не могу понять в чем беда. Проблема при использовании скобок. А если вводить что-то типа...

Из инфиксной нотации в постфиксную
Здравствуйте, прошу помощи, есть класс в нем методы. Суть программы в том что она должна переводить из инфиксной нотации в постфисную, но...

Перевести выражение из инфиксной формы в постфиксную
Помогите пожалуйста написать программу. Дана строка, в которой записано математическое выражение в инфиксной форме. В этой строке могут...

6
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
14.02.2015, 08:48
Она вообще ничего не возвращает - void. Внутри функции OutStr правильно формируется?
74-я строка не понятно для чего, память же не выделялась. 69-73 должны быть в деструкторе класса Stack.
0
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,246
14.02.2015, 10:07
Строка 75
Цитата Сообщение от DevilRigoll Посмотреть сообщение
Str=OutStr;
Это разве не скрытый возврат значения (по ссылке)?
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
14.02.2015, 10:15
Да, но выражение "функция возвращает значение" имеет вполне конкретный смысл.
0
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,246
14.02.2015, 10:22
Ну напишите вид возвращаемого значения не void, а string
и в конце функции
C++
1
 return OutStr;
Вызов
C++
1
 string result=InficsToPostfics(Str);
0
1 / 1 / 1
Регистрация: 09.04.2014
Сообщений: 71
14.02.2015, 15:46  [ТС]
zss,
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
#include<iostream>
#include<string>
#include<conio.h>
#include<cstdlib>
 
#include"ClassStack.h"
 
using namespace std;
 
 
 
int PrioritySign(char w)
{
    switch(w)
    {   
        case '^':
            return 4;
        case '/':
        case '*':
            return 3;
        case '+':
        case '-':
            return 2;
        case '(':
            return 1;       
    }
}
 
string InficsToPostfics(string &Str)
{
    Stack Stc;
    string OutStr;
       for(int i = 0; i < Str.size(); i++)
       {
           if(Str[i] == '(')
              Stc.AddHead(Str[i]);
           if(Str[i] == ')')
           { 
              while(Stc.Head != 0)
              {
                 if(Stc.Head->Text == '(')
                 {
                    Stc.DeleteHead();
                    break;
                 }
                 OutStr += Stc.Head->Text;
                 Stc.DeleteHead();  
              } 
           }  
           if((Str[i] == '*')||(Str[i] == '-')||(Str[i] == '+')||(Str[i] == '/')||(Str[i] == '^'))
           {
              if(Stc.Head == NULL)
                 Stc.AddHead(Str[i]);
              else
              {  
                 while((Stc.Head != NULL)&&(PrioritySign(Stc.Head->Text) > PrioritySign(Str[i])))
                 {
                    OutStr += Stc.Head->Text;
                    Stc.DeleteHead();
                 }
                 Stc.AddHead(Str[i]);
              }
           }
           else
           {
              OutStr += Str[i];
           }
       }
     while(Stc.Head != 0)
     {
        OutStr += Stc.Head->Text;
        Stc.DeleteHead();
     }    
     return OutStr;
      
}
 
int main()
{
    string Str;
    cout << "Enter string" << endl;
    cin >> Str;
    
    string result = InficsToPostfics(Str);
    cout << result;
    getch();
    return 0;
}
сделал как вы сказали, но всё равно ничего не выводит
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
14.02.2015, 15:50
Так может дело в самом алгоритме, а не в строках? Отладчиком проверяй.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.02.2015, 15:50
Помогаю со студенческими работами здесь

Написать программу преобразования инфиксной формы выражения в постфиксную (память)
Возникает проблема с использованием памяти. Не могу исправить. Точка останова срабатывает в функции removeAll #include...

Перевод из инфиксной в постфиксную
#define _CRT_SECURE_NO_WARNINGS #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; #include &lt;math.h&gt; #include &lt;string.h&gt; struct list{ ...

Перевод из инфиксной в постфиксную
ПОМОГИТЕ ПОЖАААЛУЙСТА!!! НУЖНА ПРОГРАММА ПЕРЕВОД ИЗ ИНФИКСНОЙ В ПОСТФИКСНУЮ ФОРМУ ( ГДЕ САМО ВЫРАЖЕНИЕ ВВОДИТСЯ С КЛАВИАТУРЫ ) ...

Перевод из инфиксной записи в постфиксную
Программа очень сырая и вообще не работает вовсе. Как исправить ее? def rpn(s): lex=parse(s) s2= r= oper= ...

Перевод инфиксной формы в постфиксную
Пишу программу для перевода из инфиксной системы в постфиксную, при работе программы выдает ошибку EAccessviolation, и указывает на Stack....


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru