Problem J: 零起点学算法105-C语言合法标识符
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
C语言的标识符指保留字(for,int,if等)和用户定义的变量名。
C语言的标识符由字母、数字和下划线组成,其中第一个字符必须是字母或者下划线。
代码实现
#include<bits/stdc++.h> using namespace std; int main() { string s; int n,i,flag; while(cin>>n) { getchar(); while(n--) { flag=1; getline(cin,s); for(i=0;i<s.size();i++) { if(i==0) { if(!((s[i]<='z' && s[i]>='a') || (s[i]<='Z' && s[i]>='A') || s[i]=='_')) { flag=0; break; } } else if(!((s[i]<='z' && s[i]>='a') || (s[i]<='Z' && s[i]>='A') || s[i]=='_' || (s[i]<='9' && s[i]>='0'))) { flag=0; break; } } if(flag) cout<<"yes"<<endl; else cout<<"no"<<endl; } } return 0; }