先看问题描述
描述
假设一个算术表达式中可以包含三种括号:圆括号“(”和“)” 、方圆括号“[”和“]”、和花括号“{”和“}”,且这三种括号可按任意的次序嵌套使用(如:…[…{…}…[…]…]…[…]…(…)…)。编写判别给定表达式中所含括号是否正确配对出现的算法。若正确配对则输出yes,否则输出no。

输入

测试数据有多组,处理到文件尾。每组测试数据在同一行中输入不超过50个字符的算术表达式(不要求算术表达式一定合法)。

输出

根据算术表达式中的括号是否正确配对输出yes或no。

样例输入

a*[b+c*{d-e}+5*6-[7*8]*9]+[3*10]+5*18*(3*e)+5
3-[4+c*{9-5}+a*6-[d*e]+3
3-{[((()))]}+3

样例输出

yes
no
yes


鄙人纯C代码

#include<stdio.h> #include<stdlib.h> #define MAX 101 typedef struct node { char flag; struct node *next; }linklist; linklist* push(linklist *last,char w) { linklist*p=(linklist*)malloc(sizeof(linklist)); p->flag=w; p->next=last; return p; } int main() { char a[MAX]; while(gets(a)) { bool result=0; int i; linklist*p=push(NULL,NULL); for(i=0;a[i];i++) { int x=2; switch (a[i]) { case '(':x--; case '[': case '{': p=push(p,a[i]+x); break; case ')': case ']': case '}': { if(p->next==NULL) goto END; /*这里缺了free(空间),要小心*/ else { if(a[i]==p->flag) p=p->next; else goto END; } } } } if(p->next==NULL) result=1; END:puts(result?"yes":"no"); } return 0; }

还有C++版的代码

#include<stack> using namespace std; bool GetResult(char *a) { stack<char>p; for(int i=0,x;a[i];i++) { x=2; switch (a[i]) { case '(':x--; case '[': case '{':p.push(a[i]+x);break; case ')': case ']': case '}': { if(!p.empty()&&a[i]==p.top()) p.pop(); else return 0; } } } return p.empty(); } int main() { char string_buffer[150]; while(gets(string_buffer)) puts(GetResult(string_buffer)?"yes":"no"); return 0; }

文章作者: qbeenslee

CC BY-NC 4.0