1 / 1 / 1
Регистрация: 09.04.2014
Сообщений: 71

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

14.02.2015, 07:16. Показов 3238. Ответов 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
13778 / 10971 / 6491
Регистрация: 18.12.2011
Сообщений: 29,253
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
13778 / 10971 / 6491
Регистрация: 18.12.2011
Сообщений: 29,253
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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru