m0_74079850 2022-11-26 12:33 采纳率: 96.3%
浏览 13
已结题

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

题目:
如果一串字符从左至右读和从右至左读相同,那么这串字符就是回文(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

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

  • 写回答

3条回答 默认 最新

  • 关注

    因为你的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

    展开全部

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

    判断回文的时候,需要整个for循环全部执行完毕,也就是前半部分字符串和后半部分字符串完全对称才是回文串,你的代码的逻辑是只要有一对相等就直接return 1了,所以是错误的。

    回复

    如有帮助,请帮忙采纳一下,多谢啦。

    img

    回复
查看更多回答(2条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 12月4日
  • 已采纳回答 11月27日
  • 创建了问题 11月26日

悬赏问题

  • ¥15 编译python程序为pyd文件报错:{"source code string cannot contain null bytes"
  • ¥20 关于#r语言#的问题:广义加行模型拟合曲线后如何求拐点
  • ¥15 fluent设置了自动保存后,会有几个时间点不保存
  • ¥20 激光照射到四象线探测器,通过液晶屏显示X、Y值
  • ¥15 这怎么做,怎么在我的思路下改下我这写的不对
  • ¥50 数据库开发问题求解答
  • ¥15 安装anaconda时报错
  • ¥15 小程序有个导出到插件方式,我是在分包下引入的插件,这个export的路径对吗,我看官方文档上写的是相对路径
  • ¥20 希望有人能帮我完成这个设计( *ˊᵕˋ)
  • ¥100 将Intptr传入SetHdevmode()将Intptr传入后转换为DEVMODE的值与外部代码不一致
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部