这周我做了字符串类型的题目,虽然不是很难,但也记录一下。
题目如下:
输入一个字符串,判断其是否是C的合法标识符。
Input
输入数据包含多个测试实例,数据的第一行是一个整数n,表示测试实例的个数,然后是n行输入数据,每行是一个长度不超过50的字符串。
Output
对于每组输入数据,输出一行。如果输入数据是C的合法标识符,则输出"yes",否则,输出“no”。
Sample Input
3
12ajf
fi8x_a
ff ai_2
Sample Output
no
yes
no
代码:
#include<stdio.h>
int main()
{
int n,i,lag;
char a[50];
scanf("%d",&n);
getchar();
while(n--)
{
lag=0;
gets(a);
if((a[0]>='a' && a[0]<='z')||(a[0]>='A' && a[0]<='Z')|| a[0]=='_')//判断字符是否合法
{
for(i=1;a[i]!='\0';i++){
if((a[i]>='a' && a[i]<='z')||(a[i]>='A' && a[i]<='Z')|| a[i]=='_' || (a[i]>='0' && a[i]<='9'))
lag=1;
else{
lag=2;
break;
}
}
if(lag==1)
printf("yes\n");
else
printf("no\n");
}
else{
printf("no\n");
}
}
return 0;
}