【问题描述】
编写程序,统计给定的C源程序中花括号的最大嵌套层次,并输出花括号嵌套序列,该程序没有语法错误。
注意:
1)源程序注释(/* … */)中的花括号应被忽略,不参与统计。
2)源程序中的字符串常量不会出现花括号。
【输入形式】
要检查的C源程序文件名为input.c,在当前目录下。
【输出形式】
向控制台输出花括号的最大嵌套层次数,并在新的一行上按出现的先后顺序输出花括号。
【样例输入】
假如当前目录下input.c文件的内容为:
#include
main()
{
int a,b,i,sum1,sum2;
/*{input}*/
scanf("%d%d",&a,&b);
sum1=sum2=0;
for(i=a;i<=b;i++)
{
if(i%2==0)
{
sum1+=i;
}
else
{
sum2+=i;
}
}
/*{output}*/
printf("Sum1=%d, Sum2=%d",sum1,sum2);
}
【样例输出】
3
{{{}{}}}
【样例说明】
源程序input.c中的花括号的最大嵌套层次为3,所以输出3。然后顺序输出出现的花括号(注释中的花括号应被忽略),即:{{{}{}}}。
【评分标准】
该题要求输出源程序中花括号的最大嵌套层次数及花括号序列,共有5个测试点。上传C语言文件名为exam3.c。
#include #include#include#include
using namespacestd;intmain() {
freopen("input.c", "r", stdin);chart;char ans[1000];//储存答案
stackmystack;int len = 0;int flag = 0;int max_sum = 0;int sum = 0;while (cin >>t) {if (t == ‘/‘)
flag++;if (flag % 2 == 0) {if (t == ‘{‘) {
ans[len++] = ‘{‘;
mystack.push(t);
sum++;
}else if (t == ‘}‘) {
ans[len++] = ‘}‘;
mystack.pop();
sum--;
}
}
max_sum=max(max_sum, sum);
}
ans[len]= ‘