c++ 关于用栈检验括号是否匹配问题

zunjiongliu7166 2017-10-17 09:33:15
先拿出部分代码

bool BracketsCheck(char* article)
{
int i=0;
SNode *A;
InitStack(A);
char ch;
while(article[i]!='/0')
{
ch=article[i];
i++;
switch(ch)
{
case '(':
case '{':
case '[':
Push(A,ch);
break;
case ')':
if(Peek(A)=='(')
Pop(A);
else
return false;
break;
case '}':
if(Peek(A)=='{')
Pop(A);
else
return false;
break;
case ']':
if(Peek(A)=='[')
Pop(A);
else
return false;
}
}
if(Empty(A))
return 1;
else
return 0;
}

ElemType Peek(SNode*& HS)
{
if(HS==NULL)
{
cout<<"Empty!"<<endl;
exit(1);
}
return HS->date;
}

我要检验一段字符串,一开始是定义一个空栈,可是当调用Peek函数的时候,就会出现空栈所以HS==NULL,因此exit无法继续检验,我想问怎么处理这个问题
...全文
107 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

64,639

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧