判断是否是回文字符串的c语言程序
时间: 2024-12-23 10:15:14 浏览: 7
判断一个字符串是否是回文的,即正读和反读都一样,可以用C语言编写一个简单的程序。以下是一个基本的示例:
```c
#include <stdio.h>
#include <string.h>
int isPalindrome(char str[]) {
int length = strlen(str);
for (int i = 0; i < length / 2; i++) {
if (str[i] != str[length - 1 - i]) { // 比较首尾字符是否相等
return 0; // 如果不等,则不是回文
}
}
return 1; // 遍历完都没发现不等的字符,说明是回文
}
int main() {
char input[100];
printf("请输入一个字符串:");
fgets(input, sizeof(input), stdin); // 注意去除fgets带来的换行符
input[strcspn(input, "\n")] = '\0'; // 替换换行符
if (isPalindrome(input)) {
printf("%s 是一个回文字符串。\n", input);
} else {
printf("%s 不是回文字符串。\n", input);
}
return 0;
}
```
在这个程序中,`isPalindrome` 函数比较字符串的第一个字符和最后一个字符,然后依次向中间移动,直到找到不相等的字符或者遍历完整个字符串。如果整个过程都没有发现不匹配的字符,那么就返回1表示是回文。
阅读全文