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<iostream>
#include<cstring>
using namespace std;
int main()
{
int t,k,n,i;
char a[52];
cin>>t;
getchar();//消除回车键
while(t--)
{
gets(a);//使用这个函数第一个字符的位置为0
n=strlen(a);
if((a[0]>='a'&&a[0]<='z')||(a[0]>='A'&&a[0]<='Z')||(a[0]=='_'))//先判断第一个字符
{
k=0;
for(i=1;i<n;i++)
{
if((a[i]>='a'&&a[i]<='z')||(a[i]>='A'&&a[i]<='Z')||(a[i]>='0'&&a[i]<='9')||(a[i]=='_'))
{
k++;
}
}
if(k==(n-1))
{
cout<<"yes";
}
else
cout<<"no";
}
else
cout<<"no";
cout<<endl;
}
return 0;
}
2540

被折叠的 条评论
为什么被折叠?



