C语言合法标识符
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 70614 Accepted Submission(s): 27473
Problem Description
输入一个字符串,判断其是否是C的合法标识符。
Input
输入数据包含多个测试实例,数据的第一行是一个整数n,表示测试实例的个数,然后是n行输入数据,每行是一个长度不超过50的字符串。
Output
对于每组输入数据,输出一行。如果输入数据是C的合法标识符,则输出”yes”,否则,输出“no”。
Sample Input
3
12ajf
fi8x_a
ff ai_2
Sample Output
no
yes
no
/*此题只要抓住C语言合法标识符的命名规则就可以了
(1、首元素只能是下划线或是字母,2、除首元素外的元素只能是数字、下划线和字母),
先判断输入的字符串首元素是否符合规则,接着再判断其他元素。
要注意的是因为输入的是字符串,则在判断元素是否是数字时是与字符数字判断!!!*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
int n,i,flag,l;
char a[50];
while(scanf("%d",&n)!=EOF)
{
getchar();
while(n--)
{
memset(a,0,sizeof(a));
gets(a);
flag=0;
l=strlen(a);
if(!(a[0]=='_'||(a[0]-'a'>=0&&a[0]-'z'<=0)||(a[0]-'A'>=0&&a[0]-'Z'<=0)))
printf("no\n");
else
{
for(i=1;i<l;i++)
{
if((a[i]>='0'&&a[i]<='9')||(a[i]>='a'&&a[i]<='z')||(a[i]-'A'>=0&&a[i]-'Z'<=0)||a[i]=='_')
flag++;
}
if(flag==l-1)
printf("yes\n");
else
printf("no\n");
}
}
}
return 0;
}