void transform(char suffix[], char exp[])
{
OPTR s;
char *p;
char ch='\0',c='\0';
int k = 0,e='\0';
p = exp;
ch = *p;
InitStack(s);
Push(s, '#');
while (Gettop(s, e) != '#')
{
if (ch >= '0' && ch <= '9')
suffix[k++] = ch;
else
{
switch (ch)
{
case'(':Push(s, ch); break;
case')':
{
Pop(s, c);
while (c != '(')
{
suffix[k++] = c; Pop(s, c);
}
break;
}
default:
{
while (Gettop(s, c) && (precede(c, ch)))
{
suffix[k++] = c; Pop(s, c);
}
if (ch != '#')Push(s, ch);
break;
}
}
}
if (ch != '#')ch = *++p;
}
suffix[k++] = '\0';
}请问这段将算术表达式转变为后缀表达式的代码有问题吗
C语言初学者,关于表达式求值,求解答
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
悬赏问题
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 ubuntu子系统密码忘记
- ¥15 保护模式-系统加载-段寄存器
- ¥15 电脑桌面设定一个区域禁止鼠标操作
- ¥15 求NPF226060磁芯的详细资料