对输入的一段c或者c++代码(只要求其中一种),检查各种括号是否配对,以及配对的情况。 5
具体要求:1、假设一个算术表达式中可包含三种括号:圆括号、中括号、花括号且这三种2、括号可按任意次序嵌套使用。利用栈的运算,编写判别给定式中所含括号是否正确配对出现的算法...
具体要求:
1、假设一个算术表达式中可包含三种括号:圆括号、中括号、花括号且这三种
2、括号可按任意次序嵌套使用。利用栈的运算,编写判别给定式中所含括号是否正确配对出现的算法。
3、若代码中有注释,能够自动忽略注释内容
4、任意输入一个括号的位置,能够打印出与之配对的括号的位置
5、【可选】允许用户规定括号的嵌套顺序,重新运行本系统
6、【可选】能够去掉代码中多余的括号 展开
1、假设一个算术表达式中可包含三种括号:圆括号、中括号、花括号且这三种
2、括号可按任意次序嵌套使用。利用栈的运算,编写判别给定式中所含括号是否正确配对出现的算法。
3、若代码中有注释,能够自动忽略注释内容
4、任意输入一个括号的位置,能够打印出与之配对的括号的位置
5、【可选】允许用户规定括号的嵌套顺序,重新运行本系统
6、【可选】能够去掉代码中多余的括号 展开
1个回答
展开全部
#include<stdio.h>
#include<string.h>
char a[10010];
int main()
{
int n;
scanf("%d",&n);
while(n--)
{
int i,len,top=0;
scanf("%s",a);
len=strlen(a);
for(i=1;i<len;i++)
{
if(a[i]==']'&&a[top]=='['||a[i]==')'&&a[top]=='(')
--top;
else
{
++top;
a[top]=a[i];
}
}
if(top==-1)
printf("Yes\n");
else
printf("No\n");
}
return 0;
}
#include<string.h>
char a[10010];
int main()
{
int n;
scanf("%d",&n);
while(n--)
{
int i,len,top=0;
scanf("%s",a);
len=strlen(a);
for(i=1;i<len;i++)
{
if(a[i]==']'&&a[top]=='['||a[i]==')'&&a[top]=='(')
--top;
else
{
++top;
a[top]=a[i];
}
}
if(top==-1)
printf("Yes\n");
else
printf("No\n");
}
return 0;
}
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询