6-4 判断回文 (12 分)

如果一串字符从左至右读和从右至左读相同,那么这串字符就是回文(Palindrome)。例如,ABCBA是回文,而ABCD则不是。本题要求编写一个判断字符串是否为回文的函数,并且通过函数参数获取字符串的中间字符(如果中间是两个字符,则获取靠左的那一个,例如字符串是ABCDEF,则中间字符是C)。题目保证输入的字符串长度在1至2000之间且不含空格、换行等分隔符。

函数接口定义:

 

int isPalindrome(const char* str, char* pch);

其中 str 和 pch 都是用户传入的参数。 str 是字符串的首地址; pch 是传入的要存放字符串中间字符的变量的地址。如果字符串是回文,函数须返1,否则返回0。

裁判测试程序样例:

 

/* 测试程序仅为示例,实际的测试程序可能不同 */ #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; } /* 你编写的函数代码将被嵌在这里 */

输入样例:

ABCDACBC

输出样例:

不是回文!中间字符是D
int isPalindrome(const char* str, char* pch)
{
    int len,i,j;
    len=strlen(str);
    i=0,j=len-1;
    if(len%2==0)
    {
        *pch=*(str+len/2-1);
    }
    else
    {
        *pch=*(str+(len-1)/2);
    }
    for(i=0;i<j;i++,j--)
    {
        if(*(str+i)!=*(str+j))
        {
            return 0;
        }    
    }
    return 1;
}    

最开始的时候想法过于复杂,想的是正序与逆序的直接比较。借鉴了别人的思路后难度大大降低。还是大体分两部分:一部分找中间值(其实这里一首一尾已经提示了接下来的做法) 分情况讨论即可;另一部分是利用之前的一首一尾,从两边开始依次比较字符,只要有不同的就结束循环,否则就是回文。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值