2012年北航机试:
T3:统计关键字
输入一行标准c语言代码(字符个数小于300),统计出该字符串中关键字的if,while,for所在的位置,按照关键字出现的顺序依次输出。注意双引号内的不需要统计。输入:一行标准c语言代码,字符个数小于300
输出:关键字if,while,for对应的位置,按照关键字出现的顺序依次输出。输出格式为:关键字,后跟冒号,然后是出现的位置。扫描到关键字就输出,每个输出占一行。
样例输入:
#include <stdio.h> int main() {int i = 0; if(i == 0) printf("YES"); return 0;}
#include <stdio.h> int main() {int ifwhile = 0; int forif = 1;char if_for_while = 'a';char *str = "while"; while(ifwhile == 0) {ifwhile = 1;forif = 0;} if(forif == 0) {if_for_while = 'b';} if(ifwhile == 1) {if_for_while = 'c';} return 0;}
样例输出:
if:43
while:88
if:133
if:170
这道题感觉回忆题目的人把答案搞错了 样例2的输出应该是while:108 if:153 if:190
分析:遇到"就利用循环跳过双引号内的字符
if前后可能出现的符号:
if(
}if
}if
;if
if前后均可以跟空格
while前后可能出现的字符与if相同
源码如下:
#include <stdio.h>
#include <string.h>
char s[302];
int main(){
int i,w;
int len;
freopen("3.txt","r",stdin);
i=0;
w=0;
while(gets(s)){
len=strlen(s);
for(i=0;i<len;i++){
if(s[i]=='"')
while(s[i]!='"')i++;
if(s[i]=='i'){
if(s[i+1]=='f'&&
(s[i+2]=='('||s[i+2]==' ')&&
(s[i-1]==' '||s[i-1]=='}'||s[i-1]=='{'||s[i-1]==';'))
printf("if:%d\n",i+1);
}
else if(s[i]=='w'){
if(s[i+1]=='h'&&s[i+2]=='i'&&s[i+3]=='l'&&s[i+4]=='e'&&
(s[i+5]=='('||s[i+5]==' ')
&&(s[i-1]==';'||s[i-1]==' '||s[i-1]=='}'||s[i-1]=='{'))
printf("while:%d\n",i+1);
}
}
}
return 0;
}