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

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

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

Author24 — интернет-сервис помощи студентам
Суть моей программы: перевод из инфиксной в постфиксную запись.
Но проблема в том, что функция типа 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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
14.02.2015, 07:16
Ответы с готовыми решениями:

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

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

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

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

6
7803 / 6567 / 2988
Регистрация: 14.04.2014
Сообщений: 28,706
14.02.2015, 08:48 2
Она вообще ничего не возвращает - void. Внутри функции OutStr правильно формируется?
74-я строка не понятно для чего, память же не выделялась. 69-73 должны быть в деструкторе класса Stack.
0
Модератор
Эксперт С++
13701 / 10904 / 6472
Регистрация: 18.12.2011
Сообщений: 29,110
14.02.2015, 10:07 3
Строка 75
Цитата Сообщение от DevilRigoll Посмотреть сообщение
Str=OutStr;
Это разве не скрытый возврат значения (по ссылке)?
0
7803 / 6567 / 2988
Регистрация: 14.04.2014
Сообщений: 28,706
14.02.2015, 10:15 4
Да, но выражение "функция возвращает значение" имеет вполне конкретный смысл.
0
Модератор
Эксперт С++
13701 / 10904 / 6472
Регистрация: 18.12.2011
Сообщений: 29,110
14.02.2015, 10:22 5
Ну напишите вид возвращаемого значения не 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  [ТС] 6
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
7803 / 6567 / 2988
Регистрация: 14.04.2014
Сообщений: 28,706
14.02.2015, 15:50 7
Так может дело в самом алгоритме, а не в строках? Отладчиком проверяй.
0
14.02.2015, 15:50
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
14.02.2015, 15:50
Помогаю со студенческими работами здесь

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru