判断回文(指针与一维数组)

题目:
如果一串字符从左至右读和从右至左读相同,那么这串字符就是回文(Palindrome)。例如,ABCBA是回文,而ABCD则不是。本题要求编写一个判断字符串是否为回文的函数,并且通过函数参数获取字符串的中间字符(如果中间是两个字符,则获取靠左的那一个,例如字符串是ABCDEF,则中间字符是C)。题目保证输入的字符串长度在1至2000之间且不含空格、换行等分隔符。
函数接口定义:
int isPalindrome(const char* str, char* pch);
其中 str 和 pch 都是用户传入的参数。 str 是字符串的首地址; pch 是传入的要存放字符串中间字符的变量的地址。如果字符串是回文,函数须返1,否则返回0。
裁判员程序样例:

img

/* 你编写的函数代码将被嵌在这里 */
输入样例:
ABCDACBC
输出样例:
不是回文!中间字符是D

正确答案:

img


我的错误答案:

img

请问我和正确答案不一样的那部分 为什么是答案那样写而不是我这样写呢?
谢谢!

因为你的for循环中,只要有1对字符相等就return1了,而实际需要整个for循环都执行完毕才是真正的回文串。

比如ABCA这个字符串,len=4,你的代码,for循环中,当i=0时,*stri是A,*str(len-i-1)也是A,满足if条件,这时候你的代码直接return 1了,是不对的。
而且,你的代码中也写错了,没有stri这个变量,你的if语句中写成 stri 了
另外,你认为正确的代码也是错误的,正确的写法应该是下面的:

#include <stdio.h>
#include <string.h>
#define MAXLENGTH 100
int isPalindrome(const char* str, char* pch);
int main()
{
    char str[MAXLENGTH], mid;
    scanf("%s", str);
    if (isPalindrome(str, &mid))
        printf("是回文!中间字符是%c\n", mid);
    else
        printf("不是回文!中间字符是%c\n", mid);
    return 0;
}
int isPalindrome(const char* str, char* pch)
{
    int i;
    int len;
    len = strlen(str);
    *pch = str[(len - 1) / 2];
    for (i = 0; i < (len - 1) / 2; i++)
    {
        if (str[i] == str[len - i - 1])
            continue;
        else
            return 0;
    }
    return 1;
}

运行结果:

img

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632