C语言合法标识符
Time Limit: 1000 ms Memory Limit: 65536 KiB
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
Hint
Source
HDOJ
#include <stdio.h>
#include <string.h>
int main()
{
char s[110];
int i, flag, n, j;
scanf("%d%*c", &n);
for(j = 0; j <= n - 1; j++)
{
gets(s);
flag = 0;
for(i = 0; i <= strlen(s) - 1; i++)
{
if(i == 0)
{
if((s[i] >= 'a' && s[i] <= 'z')||(s[i] >= 'A' && s[i] <= 'Z')||(s[i] == '_'))
{
flag = 1;
}
}
else
{
if((s[i] >= 'a' && s[i] <= 'z')||(s[i] >= 'A' && s[i] <= 'Z')||(s[i] == '_')||(s[i] >= '0' && s[i] <= '9'));
else
break;
}
}
if(flag == 1 && i == strlen(s))
printf("yes\n");
else
printf("no\n");
}
return 0;
}