SDUT-1246 C语言合法标识符(JAVA*)

C语言合法标识符

Time Limit: 1000 ms  Memory Limit: 65536 KiB
Submit  Statistic

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();
	}
}

你可能感兴趣的:(JAVA,SDUT-OJ)