C语言合法标识符
Time Limit: 1000 ms
Memory Limit: 65536 KiB
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
Hint
Source
HDOJ
package leslie;
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
while (input.hasNext()) {
int n = input.nextInt();
String getchar = input.nextLine(); //记得消去n和后面字符串之间的换行
while (n != 0) {
n--;
int flag = 1;
char arr[] = input.nextLine().toCharArray();
for (int i = 0; i < arr.length; i++) {
if (i == 0) {
if ((arr[i] >= 'a' && arr[i] <= 'z') || (arr[i] >= 'A' && arr[i] <= 'Z') || arr[i] == '_') {
continue;
} else {
flag = 0;
}
} else {
if ((arr[i] >= 'a' && arr[i] <= 'z') || (arr[i] >= 'A' && arr[i] <= 'Z') || arr[i] == '_'
|| (arr[i] >= '0' && arr[i] <= '9')) {
continue;
} else {
flag = 0;
}
}
if (flag == 0)
break;
}
if (flag == 1)
System.out.printf("yes\n");
else
System.out.printf("no\n");
}
}
input.close();
}
}