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 |
#include <ctype.h>
/*字符测试函数 isalpha
函数原型: int isalpha(int ch); 函数功能: 检查ch是否是字母. 函数返回: 是字母返回1 ,否则返回 0 */
#include <stdio.h>
int main(void)
{
int n, d, i;
char sym[64];
scanf("%d%*c", &n);
while (n--)
{
gets(sym);
if (sym[0] != '_' && !isalpha(sym[0]))
{
puts("no");
continue;
}
for (d = i = 1 ; sym[i] ; i++)
{
if (!isalnum(sym[i]) && sym[i] != '_')
{
d = 0;
break;
}
}
puts(d ? "yes" : "no");
}
return 0;
}