小珂的编译器
时间限制:3000 ms | 内存限制:65535 KB
难度:2
描述
小珂今天刚学了编译原理,老师给她了一个作业。让他求出一段程序中给定的关键字的个数。请你帮她写一个程序,计算出结果并输出。
输入
第一行有一个整数1<n<=10,表示有n个测试数据。
随后的n组数据的每一行有一个整数0<m<=6,表示要统计的关键字的个数。接着是m行是m个关键字。接着是一段C++程序,遇到字符‘@’表示程序结束(保证‘@’占独立的一行)。同时保证,输入的一段无语法错误的C++程序段,不包括预处理语句,也就是不包含用‘#’开头的语句。同时保证所有的关键字一定是char,double,float,const,int,string中的一个。程序的行数少于100行。同时保证,字符串中不会出现关键词或者包含关键词的单词。
输出
输出n行,统计出要求统计的关键字出现的总次数。
样例输入
2
4
char
int
double
float
int main()
{
inta=10;
cout<<a<<endl;
}
@
1
int
int main()
{
int*p;
}
@
代码:
#include<stdio.h>
#include<string.h>
int main(void)
{
int m,n=0,i,j,count;
char ch[7][10],str[500],p;
scanf("%d",&m);
while(m--)
{
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%s",ch[i]);
}
count=0;
i=0;
while(scanf("%c",&p)&&p!='@')
{
if((p>='a'&&p<='z')||(p>='0'&&p<='9')||p=='_')
str[i++]=p;
else
{
for(j=0;j<n;j++)
{
if(strcmp(str,ch[j])==0)
{
count++;
}
}
memset(str,0,sizeof(str));
i=0;
}
}
printf("%d\n",count);
}
return 0;
}