实验8-2-5 判断回文字符串 (20 分)

复制代码
#include <stdio.h>
#include <string.h>

#define MAXN 20
typedef enum { false, true } bool;

bool palindrome(char *s);

int main()
{
    char s[MAXN];

    scanf("%s", s);
    if (palindrome(s) == true)
        printf("Yes\n");
    else
        printf("No\n");
    printf("%s\n", s);

    system("pause");
    return 0;
}

/* 你的代码将被嵌在这里 */
bool palindrome(char *s) {
    int i;
    int n = strlen(s);
    if (n % 2 == 0) {
        for (i = 0; i < (n - 1) / 2; i++)
            if (s[i] != s[n - 1 - i])
                return false;
    }
    else {
        for (i = 0; i < n / 2; i++)
            if (s[i] != s[n - 1 - i])
                return false;
    }
    return true;
}
复制代码

此代码可进行优化。

posted @   JamesGordan  阅读(91)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示