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
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
#include
#include
#include
#include
#include
#include
#include
#include
#define LL long long
#define INF 0x7fffffff
#define MAX 200010
using namespace std;
int t;
int main()
{
char a[100];
int t;
scanf("%d\n",&t);
while(t--)
{
gets(a);
if(!isalpha(a[0])&&a[0]!='_')
{
printf("no\n");
continue;
}
int flag=1;
int l=strlen(a);
for(int i=1;i
{
if(a[i]!='_'&&!isalnum(a[i]) && !(a[i]>='0' && a[i]<='9'))
{
flag=0;
break;
}
else
{
flag=1;
}
}
if(flag==1)
{
printf("yes\n");
}
else if(flag==0)
{
printf("no\n");
}
}
return 0;
}
我以前自己写的,大致看着差不多