所以这是我为大学做的一项功课。我必须从文本文件中的一行读取一个波兰表示法。文本文件中的表达式为:" / 2 3"我必须把它变成反向抛光表示法。我一直收到此错误:0xC0000005:访问冲突读取位置0x00000000。
int top = -1;
char prefix[50];
void Push(char value)
{
top++;
prefix[top] = value;
}
void Pop()
{
if (top < 0)
cout << "The stack is empty." << endl;
else
{
top--;
}
}
char Top()
{
return prefix[top];
}
void Display()
{
for (int i = 0; i <= top; i++)
cout << prefix[i] << " ";
}
bool isOperator(char c)
{
if (c == '+' || c == '-' || c == '*' || c == '/')
return true;
else
return false;
}
char c;
char postfix[50];
int top2 = -1;
void Push2()
{
top2++;
postfix[top2] = Top() + Top() + c;
}
void Display2()
{
{
for (int i = 0; i <= top2; i++)
cout << postfix[i] << " ";
}
};
void PrefixToPostfix()
{
for (int *i = 0; *i <= top2; i++)
{
c = prefix[*i];
if (isOperator)
{
Push2();
}
else
{
top2++;
postfix[top2] = c;
}
}
}
int _tmain(int argc, _TCHAR* argv[])
{
char value;
char c;
ifstream file("Prefix.txt");
while (file >> value)
{
Push(value);
}
file.close();
PrefixToPostfix();
Display();
Display2();
cout << endl;
system("PAUSE");
return 0;
}
我认为错误可能出现在我的代码的这一部分:
void PrefixToPostfix()
{
for (int *i = 0; *i <= top2; i++)
{
c = prefix[*i];
如果有人可以帮助我,我会非常感激,因为我必须在5个小时内完成作业。 :)
答案 0 :(得分:2)
这里不需要指针:
for (int i = 0; i <= top2; i++) {
c = prefix[i]; }