某日,小明特别无聊,就想找点东西玩,于是他发现括号()特别好玩,而且新学会了一项技能,
将一对小括号(),插入到一个括号序列中,其中插入的规则是,左括号'('的位置要小于右括号')'的位置,不要求插入的左右括号相邻,
例如以下,为了方便区分,我们拿ab代表原括号序列
将()插入到()中可形成()ab (a)b (ab) a()b a(b) ab()等等序列,其中a代表原括号序列的左括号,b代表原括号序列的右括号。
小明认为一个括号序列是一个优美的序列当且仅当这个括号序列可以被如下方法构造出来:
一开始有一个空串,然后执行0次或者若干次操作,每次操作将()插入到当前的括号序列中。
根据上面的定义:() , (()) , (()())都是优美的括号序列,(() , )( , ()))都不是优美的括号序列
输入格式:
多组输入
每行输入给定一个仅由'(',')'组成的括号序列,长度小于等于1000
题目保证没有空串
输出格式:
对于每个输入输出一行,若当前的括号序列是优美的,则输出"YES"(不含引号)
否则输出"NO"(不含引号)
输入样例:
()
(())
(()())
()()
(()
)(
()))
输出样例:
YES
YES
YES
YES
NO
NO
NO
思路:我第一次想用左右括号数的相等判断,但这是错误的,如 )( ,
此题要用到数据结构中的栈结构,先进后出,顺序遍历括号,遇到左括号则出栈,遇到右括号则取出栈顶元素,相抵消,最后判断栈是否为空即可;)( 遇到这种情况,栈指针会出现异常(小于0)直接判断NO即可
#include<stdio.h>
#include<string.h>
int main() {
char data[1001][1001],stack[1001]; //一维数组模拟栈结构
int top=0,flag=0; //top栈顶指针(非实际意义中的指针)
for(int i=0;; i++)
{
gets(data[i]);
if(strlen(data[i])==0)
{
break;
}
}
for(int i=0; strlen(data[i])!=0; i++)
{
top=0; //栈指针初始化
flag=0;
for(int j=0; data[i][j]!='\0'; j++)
{
if(data[i][j]=='(') //左括号入栈
{
stack[top++]=data[i][j];
} else { //右括号与栈顶左括号抵消
top--;
if(top<0) //指针异常则直接判NO
{
flag=1;
break;
}
}
}
if(top==0&&flag==0)
{
printf("YES\n");
} else {
printf("NO\n");
}
}
return 0;
}