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

 我来答
无法无天
推荐于2018-04-11 · 知道合伙人软件行家
无法无天
知道合伙人软件行家
采纳数:658 获赞数:1756
网络工程师

向TA提问 私信TA
展开全部
  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;
}
momo7572
2018-03-30 · TA获得超过2.4万个赞
知道小有建树答主
回答量:98
采纳率:71%
帮助的人:4万
展开全部

一句话概括就是关于中心左右对称的字符串属于回文

所谓回文字符串,就是一个字符串,从左到右读和从右到左读是完全一样的。比如"level" 、 “aaabbaaa”

题目:判断一个字符串是否为回文

解法:递归

递归的作用在于把问题的规模不断缩少,直到问题缩少到能简单地解决

问:如何缩少问题规模?

答:通过观察可以知道,一个回文字符串其中内部也是回文。所以,我们只需要以去掉两端的字符的形式一层层检查,每一次的检查都去掉了两个字符,这样就达到了缩少问题规模的目的。

新问题与原问题有着相同的形式,当去掉两端字符后的字符串,其产生的新问题同样是检查这个字符串是否回文。

递归的结束需要简单情景

1. 字符串长度可能会奇数或偶数:

如果字符串长度是奇数,字符串会剩下最中间那位字符,但其不影响回文。当检查到长度为1的时候即代表此字符串是回文

如果字符串长度是偶数,当两端的字符串两两比较检查后不会剩下字符。即检查到长度为0的时候即代表此字符串是回文

2. 如果检查到两端两个字符不相同。则说明此字符串不是回文,直接返回0,不需要继续检查

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
TeaNW
2007-06-14 · TA获得超过363个赞
知道小有建树答主
回答量:87
采纳率:0%
帮助的人:0
展开全部
如果一个字符串,从左右来读都一样,就称它为回文
举个例子:
ABBA
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友5239aa2
2018-04-25
知道答主
回答量:1
采纳率:0%
帮助的人:882
展开全部

Go代码

package main

import (
    "fmt"
)

func negative(input string) {
    var flag bool  
    for i := 0; i < len(input)/2; i++ {
        if input[i] == input[len(input)-i-1] {
            flag = true
        } else {
            flag = false
            break
        }
    }
    if flag {
        fmt.Println("yes")
    } else{
        fmt.Println("no")
    }
}

func main() {
    var input string
    fmt.Scanf("%s", &input)
    negative(input)

}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
827472046
2018-04-10 · 超过11用户采纳过TA的回答
知道答主
回答量:68
采纳率:0%
帮助的人:23.2万
展开全部
Java的写法:
如果是回文则返回true,在这个函数中,认为回文的情况有
“abc”与“cba”,
“abbc”与“cbba”,
“abcde”与“edcba”。
public static boolean reverse(String str){
char[] values=str.toCharArray();
int result=values[0];
for(int i=1;i<values.length;i++){
result=result^values[i];
}
if(values.length%2!=0){
return result==values[values.length/2];
}
return result==0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式