题目描述
输入一串字符(长度小于100),判断该串字符是否是回文串(正序读与逆序读内容相同)。
输入
输入一串字符(长度小于100)。
输出
若该串字符是回文串输出“yes",否则输出”no“。
示例输入
asdfgfdsa
示例输出
yes
///方法一:用字符串的方法
#include<stdio.h>
#include<string.h>
int main()
{
int len,i,b;
char s[100],a[100];
gets(s);
len=strlen(s);
b=len;
for(i=0;i<=b-1;i++)
{
a[i]=s[len-1];
len--;
}
a[i]='\0';
if(strcmp(s,a)==0)
{
printf("yes\n");
}
else
{
printf("no\n");
}
return 0;
}
方法二:用指针的方法
#include<stdio.h>
#include<string.h>
#define N 101
int main()
{
char s[N],*pi,*pj;
int i,j,n;
gets(s);
n=strlen(s);
pi=s;
pj=s+n-1;
while(*pi==' ')
pi++;
while(*pj==' ')
pj++;
while((pi<pj)&&(*pi==*pj))
{
pi++;
pj--;
}
if(pi<pj)
printf("no\n");
else
printf("yes\n");
return 0;
}