C语言合法标识符
Time Limit: 1000MS
Memory Limit: 65536KB
Problem Description
输入一个字符串,判断其是否是C的合法标识符。
Input
输入数据包含多个测试实例,数据的第一行是一个整数n,表示测试实例的个数,然后是n行输入数据,每行是一个长度不超过50的字符串。
Output
对于每组输入数据,输出一行。如果输入数据是C的合法标识符,则输出"yes",否则,输出“no”。
Example Input
3 12ajf fi8x_a ff ai_2
Example Output
no yes no
Hint
Author
HDOJ
参考代码
#include<stdio.h>
#include<string.h>
int main()
{
char a[101];
int i,flag;
int n;
scanf("%d",&n);
getchar();
while(n--)
{
flag = 0;
gets(a);
if((a[0] >= 'a' && a[0] <= 'z') || (a[0] >= 'A' && a[0] <= 'Z') || (a[0] == '_'))
{
for(i = 0; a[i] != '\0'; i++)
{
if((a[i] >= 'a' && a[i] <= 'z') || (a[i] >= 'A' && a[i] <= 'Z') || (a[i] == '_') || (a[i] >= '0' && a[i] <= '9'))
{
flag = 1;
}
else
{
flag = 0;
break;
}
}
}
if(flag == 1)
printf("yes\n");
else
printf("no\n");
}
return 0;
}