数据结构 3.2.2链栈实现括号的匹配.doc

数据结构 3.2.2链栈实现括号的匹配.doc

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构 3.2.2链栈实现括号的匹配

3.2.2链栈实现括号匹配 /***链栈实现括号匹配***/ #includeiostream using namespace std; #define OK 1 #define ERROR 0 #define OVERFLOW -2 typedef char SElemType; typedef int Status; typedef struct SNode{ int data; struct SNode *next; }SNode,*LinkStack; Status InitStack(LinkStack S) { S = NULL; return OK; } bool StackEmpty(LinkStack S) { if(!S) return true; return false; } Status Push(LinkStack S,SElemType e) { SNode *p = new SNode; if(!p) { return OVERFLOW; } p-data = e; p-next = S; S = p; return OK; } Status Pop(LinkStack S,SElemType e) { SNode *p; if(!S) return ERROR; e = S-data; p = S; S = S-next; delete p; return OK; } Status GetTop(LinkStack S,SElemType e) { if(!S) return ERROR; e = S-data; return OK; } //算法3.9 括号的匹配 Status Matching(LinkStack S) { //检验表达式中所含括号是否正确匹配,如果匹配,则返回true,否则返回false。 //表达式以“#”结束 int flag=1; //标记查找结果以控制循环及返回结果 char c; SElemType x; cinc; //读入第一个字符 while(c!=# flag) { switch (c){ case [: case (: //若是左括号,则将其压入栈 Push(S,c); break; case ) : //若是右括号“)”,则根据当前栈顶元素的值分情况考虑 GetTop(S,x); if (!StackEmpty(S) x==( )//若栈非空且栈顶元素是“(”,则匹配成功 Pop(S,x); else flag=0; //若栈空或栈顶元素不是“(”,则非法 break; case ] : //若是右括号“]”,则根据当前栈顶元素的值分情况考虑 GetTop(S,x); if (!StackEmpty(S) x==[ ) //若栈顶元素是“[”,则匹配成功 Pop(S,x); else flag=0; //若栈空或栈顶元素不是“[”,则非法 break; }//switch cinc; //继续读入下一个字符 }//while if (StackEmpty(S) flag ) return 1; else return 0; }//Matching int main() { LinkStack S; InitStack(S); cout请输入待匹配的表达式,以#结束:endl; int flag = (int)Matching(S); if(flag) cout括号匹配成功!endl; else cout括号匹配失败!endl; return 0; }

文档评论(0)

yan698698 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档