Я работаю над проблемой преобразования инфикса в постфиксное выражение с использованием стека. Но я получаю ошибку ошибки сегментации. Я не понимаю, где я пытаюсь получить доступ к незаконной памяти?
Я подозреваю, что стековый контейнер STL вызывает некоторую проблему при вставке символов в него за пределами ограничения из-за ограничения размера, но у меня уже есть очень мало записей.
Мой код:
#include <iostream>
using namespace std;
#include <stack>
int isoperand(char ch)
{
return (ch>='a'&&ch<='z')||(ch>='A'&&ch<='Z');
}
int prec(char ch)
{
if(ch=='^')
{return 3;}
if(ch=='+'||ch=='-')
{return 1;}
if(ch=='*'||ch=='/')
{return 2; }
return -1;
}
void infixTopostfix(char arr[21])
{stack <char> s;
for(int p=0;p<21;p++)
{
if(isoperand(arr[p]))
{
cout<<arr[p];
}
else
{
if(arr[p]=='(')
{
s.push('(');
}
if(prec(arr[p])>prec(s.top()))
{
s.push('arr[p]');
}
if(arr[p]==')')
{
while(s.top()!='('||!s.empty())
{cout<<s.top();
s.pop();
}
}
if(prec(arr[p])<=prec(s.top()))
{
while(prec(s.top())>=prec(arr[p])||!s.empty())
{cout<<s.top();
s.pop();
}
}
}
}
while(!s.empty())
{
cout<<s.top();
s.pop();
}
}
int main()
{
char arr[21]={'a','+','b','*','(','c','^','d','-','e',')','^','(','f','+','g','*','h',')','-','i'};
infixTopostfix(arr);
}