/*
Copyright (c)2015,烟台大学计算机与控制工程学院
All rights reserved.
作 者:王晓慧
完成日期:2016年9月29日
版 本 号:v1.0
*问题描述:匹配括号

Copyright (c)2015,烟台大学计算机与控制工程学院
All rights reserved.
作 者:王晓慧
完成日期:2016年9月29日
版 本 号:v1.0
*问题描述:匹配括号
*/
<pre name="code" class="cpp">#include"sqstack.h"
int main()
{
char c;
char st[50];
int d=1, i;
SqStack *s;
InitStack(s);
printf("请输入表达式:");
scanf("%s", st);
for(i=0; st[i]!='\0'&&d; i++)
{
switch(st[i])
{
case'(':
case'[':
case'{':
Push(s, st[i]);
break;
case')':
Pop(s, c);
if(c!='(') d=0;
break;
case']':
Pop(s, c);
if(c!='[') d=0;
break;
case'}':
Pop(s,c);
if(c!='{') d=0;
break;
}
}
if(StackEmpty(s)&&d==1)
printf("配对正确!!\n");
else
printf("配对错误!!\n");
return 0;
}
知识点总结:匹配括号即是将表达式拆分开,依次进栈出栈,对于括号,前括号输入进栈出栈,后括号输入进栈出栈,到表达式进栈出栈完毕之后看栈内是否还有剩余的括号来判断配对是否正确。
学习心得:知识点掌握欠火候