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<algorithm> #include<string> using namespace std; int main() { int n; cin >> n; cin.ignore(); while (n > 0) { n--; string str; getline(cin, str); int flag = 1; for (int i = 1; i < str.length(); i++) { if (str[i] != '_' && !isalpha(str[i]) && !isalnum(str[i])) { flag = 0; } } if (str[0] != '_' && !isalpha(str[0])) { flag = 0; } if (flag == 0)cout << "no"; else if (flag == 1)cout << "yes"; } }
最新评论