实验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; }
此代码可进行优化。

浙公网安备 33010602011771号