如何判断一个字符串是不是回文字符串

 我来答
司马刀剑
高粉答主

2017-09-25 · 每个回答都超有意思的
知道顶级答主
回答量:4.6万
采纳率:93%
帮助的人:7578万
展开全部
  1. 首先,理解什么是回文字符串,简单的一句话概括就是关于中心左右对称的字符串。例如:ABCBA或者AACCAA是回文字符串;ABCCA或者AABBCC不是回文字符串。

  2. 判断方法就是,依次看两端的字符是否相等。例如:ABCBA,第一个字符与最后一个字符相等,第二个字符与倒数第二个字符相等,第三个字符是中心字符,无需判断。如果是AACCAA就要判断。所以上面的字符串是回文字符串。

  3. 以下是C语言实现判断回文字符串的代码。

#include<stdio.h>

#include<string.h>

int main(void)

{

char s[30];

int b=0;  //1表示不是回文字符串

puts("请输入一个字符串:");

scanf("%s",s);

for(int i=0;i<strlen(s)/2;i++)

if(s[i]!=s[strlen(s)-i-1])

{

b++;

break;

}

if(b)

printf("这不是回文字符串。");

else

printf("这是回文字符串。");

return 0;

}

自由之城66
2014-03-16 · TA获得超过230个赞
知道小有建树答主
回答量:245
采纳率:0%
帮助的人:137万
展开全部
#include<iostream.h>
#include<string.h>
class String {
private:
int y;
char *str;
public:
String (char *s);
void huiwen ();
void show ();
};
String::String (char *s){
if (s)
{
str=(char *)new char [strlen(s) 1];
strcpy (str,s);
}
else str = NULL;
}
void String::huiwen (){
if(NULL == str)
cout<<"这个字符串不是回文字符串"<<endl;
char *head = str;
char *tail=str strlen(str)-1;
for (head = &str[0];head<=tail;head ,tail--){
{
if (*head!=*tail)
{
cout<<"这个字符串不是回文字符串"<<endl;
break;
}
if(head 1>=tail)
cout<<"这个字符串是回文字符串"<<'\n';
}
}
//判断str所指向的字符串是否为回文字符串
}
void String::show(){
cout<<str<<endl;
}
void main (){
char s[100]="abffbaf";
String test(s);
test.show();
test.huiwen();
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
White_MouseYBZ
2014-03-16 · TA获得超过4万个赞
知道大有可为答主
回答量:2.1万
采纳率:82%
帮助的人:6684万
展开全部
改如下:
void main(void){
int i,j,n;
char a[5];
while(gets(a),*a!='#'){
n=strlen(a);
for(i=0,j=(n-1);i<j;++i,--j){
if(a[i]!=a[j])
break;
}
if(i>=j){
printf("Yes\n");
}
else{
printf("No\n");
}
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式