练习1:合法C标识符查
【题目描述】
给定一个不包含空白符的字符串,请判断是否是C语言合法的标识符号(注:题目保证这些字符串一定不是C语言的保留字)。
C语言标识符要求:
1.非保留字;
2.只包含字母、数字及下划线(“_”)。
3.不以数字开头。
【输入】
一行,包含一个字符串,字符串中不包含任何空白字符,且长度不大于20。
【输出】
一行,如果它是C语言的合法标识符,则输出yes,否则输出no。
【输入样例】
RKPEGX9R;TWyYcp
【输出样例】
no
#include <stdio.h>
#include <string.h>
#include <stdbool.h>
int main()
{
char a[20];
int i,len;
bool b=true,c=true;
gets(a);
len=strlen(a);
if(a[0]>='0'&&a[0]<='9')
{
b=false;
}
for(i=0;i<len;i++)
{
if((a[i]>='0'&&a[i]<='9')||(a[i]>='a'&&a[i]<='z')||(a[i]>='A'&&a[i]<='Z')||a[i]=='_')
{
}
else
{
c=false;
}
}
if(b==true&&c==true)
{
printf("yes\n");
}
else
{
printf("no\n");
}
return 0;
}
练习2:输出亲朋字符串
【题目描述】
编写程序,求给定字符串s的亲朋字符串s1。
亲朋字符串s1定义如下:给定字符串s的第一个字符的ASCII值加第二个字符的ASCII值,得到第一个亲朋字符; 给定字符串s的第二个字符的ASCII值加第三个字符的ASCII值,得到第二个亲朋字符;依此类推,直到给定字符串s的倒数第二个字符。亲朋字符串的最后一个字符由给定字符串s的最后一个字符ASCII值加s的第一个字符的ASCII值。
【输入】
输入一行,一个长度大于等于2,小于等于100的字符串。字符串中每个字符的ASCII值不大于63。
【输出】
输出一行,为变换后的亲朋字符串。输入保证变换后的字符串只有一行。
【输入样例】
1234
【输出样例】
cege
#include <stdio.h>
#include <string.h>
int main()
{
int i,len;
char s1[102],s2[102];
scanf("%s",s1);
len=strlen(s1);
for(i=0;i<len-1;i++)
s2[i]=s1[i]+s1[i+1];
s2[len-1]=s1[len-1]+s1[0];
printf("%s",s2);
return 0;
}