码迷,mamicode.com
首页 > 其他好文 > 详细

NYOJ 2 括号配对问题

时间:2014-08-15 21:14:40      阅读:220      评论:0      收藏:0      [点我收藏+]

标签:io   for   ar   2014   问题   代码   amp   时间   

/*
题目大意:求括号是否配对
解题思路:开一个数组b,来作为栈,top为栈的下个下标控制入栈和出栈
难点详解:见代码
关键点:对进栈和出栈了解深刻一点
解题人:lingnichong

解题时间:2014/08/15  19:46:45
解题体会:最基本栈的运用。一开始还不是很清楚。可以先背一下,每天睡觉前再看一下,到用的时候,再根据这个模板写出来就可以了,这样印象会更加深刻了
*/




#include<stdio.h>
#include<string.h>
#define MAXN 10000+10
char a[MAXN],b[MAXN];
int main()
{
	int n;
	int top,len;
	int i;
	scanf("%d",&n);
	getchar();
	while(n--)
	{
		
		gets(a);
		top=1;
		len=strlen(a);
		b[top++]=a[0];
		for(i=1;i<len;i++)
		{
			if(a[i]=='('||a[i]=='[')
				b[top++]=a[i];
			else
			{
				if(a[i]==')'&&b[top-1]=='(')
					--top;
				else if(a[i]==']'&&b[top-1]=='[')
					--top;
				else
					b[top++]=a[i];
			}
		}
		if(top==1)
			printf("Yes\n");
		else
			printf("No\n");
	}
	return 0;
}



NYOJ 2 括号配对问题,布布扣,bubuko.com

NYOJ 2 括号配对问题

标签:io   for   ar   2014   问题   代码   amp   时间   

原文地址:http://blog.csdn.net/qq_16767427/article/details/38589489

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!