输入一个字符串,判断其是否是C的合法标识符。
Input
输入数据包含多个测试实例,数据的第一行是一个整数n,表示测试实例的个数,然后是n行输入数据,每行是一个长度不超过50的字符串。
Output
对于每组输入数据,输出一行。如果输入数据是C的合法标识符,则输出"yes",否则,输出“no”。
Sample Input
3 12ajf fi8x_a ff ai_2
Sample Output
no yes no
这个题有趣的地方在于空格符的读入,但其实很简单,gets()
需要注意的是,要在读入第一个n的时候也用gets或者用scanf的时候加一个'\n'
#include<cstdio>
#include<string.h>
#include<iostream>
#include<algorithm>
using namespace std;
bool is_char(char a){
if((a>='a'&&a<='z')||a>='A'&&a<='Z'){
return true;
}
else return false;
}
bool is_int(char a){
if(a>='0'&&a<='9') return true;
else return false;
}
bool is_ul(char a){
if(a=='_') return true;
else return false;
}
int main(){
int n;
scanf("%d\n",&n);
char a[n][100]={"\0"};
int le[n];
for(int i=0;i<n;i++){
gets(a[i]);
le[i]=strlen(a[i]);
}
for(int i=0;i<n;i++){
int t=0;
for(int j=0;j<le[i];j++){
if(j==0){
if(is_char(a[i][j])||is_ul(a[i][j])){
t++;
}
else{
printf("no\n");
break;
}
}
if(j>0){
if(is_char(a[i][j])||is_int(a[i][j])||is_ul(a[i][j])){
t++;
}
else{
printf("no\n");
break;
}
}
}
if(t==le[i]) printf("yes\n");
}
return 0;
}