VJ,OJC语言合法标识符

    技术2022-07-10  105

    输入一个字符串,判断其是否是C的合法标识符。 Input 输入数据包含多个测试实例,数据的第一行是一个整数n,表示测试实例的个数,然后是n行输入数据,每行是一个长度不超过50的字符串。 Output 对于每组输入数据,输出一行。如果输入数据是C的合法标识符,则输出"yes",否则,输出“no”。 Sample Input 3 12ajf fi8x_a ff ai_2 Sample Output no yes no

    这是if里用“是”的关系写的AC代码

    # include<stdio.h> #include<string.h> int main() { int n, i, j; char a[60]; while(scanf("%d", &n) != EOF) { getchar(); for(i = 0; i < n; i++) { gets(a); if( ( (a[0] >= 'a' && a[0] <= 'z') || (a[0] >= 'A' && a[0] <= 'Z') || (a[0] == '_') ) )//if这里用非的关系或是的关系都可以。我开始使用非得关系 { for(j = 1; a[j] != '\0'; j++) { if(((a[j] >= 'a' && a[j] <= 'z') || (a[j] >= 'A' && a[j] <= 'Z') || (a[j] >= '0' && a[j] <= '9') || a[j] == '_')) continue; else break; } if(a[j] == '\0') printf("yes\n"); else printf("no\n"); } else printf("no\n"); } } return 0; }

    下面是用if里为“非”的关系写的AC代码

    # include<stdio.h> #include<string.h> int main() { int n, i, j; char a[60]; while(scanf("%d", &n) != EOF) { getchar(); for(i = 0; i < n; i++) { //getchar(); gets(a); if( !( (a[0] >= 'a' && a[0] <= 'z') || (a[0] >= 'A' && a[0] <= 'Z') || (a[0] == '_') ) ) { printf("no\n"); continue; } else { for(j = 1; a[j] != '\0'; j++) { if(!((a[j] >= 'a' && a[j] <= 'z') || (a[j] >= 'A' && a[j] <= 'Z') || (a[j] >= '0' && a[j] <= '9') || a[j] == '_')) { printf("no\n"); break; } } if(a[j] == '\0') printf("yes\n"); } //if(a[j] == '\0')之前写的代码一直跑不了,是因为输出放错了位置。 //printf("yes\n"); } } return 0; }
    Processed: 0.010, SQL: 9