C语言合法标识符(多组输入)

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

import java.util.Scanner;

public class Main {
        public static void main(String args[]) {
            Scanner input = new Scanner(System.in);
            while(input.hasNext()) {
                int n = input.nextInt();
                String a = input.nextLine();             //防止空格的输入存入s数组中
                while(n-- != 0) {
                    String s = input.nextLine();
                    char[] arr = s.toCharArray();
                    int i,flag = 1;
                    for(i = 0;i < arr.length;i++) {
                        if(i == 0) {
                            if((arr[i] >= 'a' && arr[i] <= 'z' )|| (arr[i] >= 'A' && arr[i] <= 'Z' )|| arr[i] == '_') {               //首字母为字母或者下划线
                                flag = 0;                                                        //若满足,则继续循环检查下一字母
                            }
                            else {
                                flag = 1;                                                        //若不满足条件,退出循环,为非法标识符
                                break;
                            }
                        }
                        else {
                            if((arr[i] >= 'a' && arr[i] <= 'z' )|| (arr[i] >= 'A' && arr[i] <= 'Z' )|| (arr[i] == '_') || (arr[i] >= '0' && arr[i] <= '9')) {             //为数字字母下划线
                                flag = 0;
                            }
                            else {
                                flag = 1;
                                break;
                            }
                        }
                    }
                    if(flag == 1) {
                        System.out.println("no");
                    }
                    else {
                        System.out.println("yes");
                    }
                }

            }
            input.close();
    }       

}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值