编程判断输入的字符串是否为“回文”。所谓“回文”是指顺读和倒读都一样,如abcba用c语言
时间: 2024-05-14 11:18:45 浏览: 131
可以使用两个指针分别指向字符串的首尾,然后逐个比较字符是否相同,直到两个指针相遇为止。如果每个字符都相同,那么就是回文字符串。
以下是用C语言实现的代码:
```c
#include <stdio.h>
#include <string.h>
int main() {
char str[100];
int i, len, flag = 1;
printf("Enter a string: ");
scanf("%s", str);
len = strlen(str);
for(i = 0; i < len/2; i++) {
if(str[i] != str[len-i-1]) {
flag = 0;
break;
}
}
if(flag) {
printf("%s is a palindrome\n", str);
}
else {
printf("%s is not a palindrome\n", str);
}
return 0;
}
```
这里使用了一个变量flag来记录是否是回文字符串,如果发现有字符不相等,则将flag置为0,表示不是回文字符串。最后根据flag的值输出相应的结果。
相关问题
用c语言编程判断一个字符串是否回文。回文就是顺读和逆读都相同,例如字符串“abcba”就是回文
可以通过以下程序判断一个字符串是否回文:
```
#include <stdio.h>
#include <string.h>
int main()
{
char str[100];
int i, len;
int flag = 1;
printf("请输入一个字符串:");
scanf("%s", str);
len = strlen(str);
for(i=0; i < len; i++)
{
if(str[i] != str[len-i-1])
{
flag = 0;
break;
}
}
if(flag)
printf("%s 是回文\n", str);
else
printf("%s 不是回文\n", str);
return 0;
}
```
输入一个字符串后,程序会依次比较字符串的首尾字符是否相等,如果不相等则该字符串不是回文,反之则是回文。
使用c语言编程实现3.输入一串字符,判断该字符串是否为“回文”(即顺读和倒读都一样,例 如:ABCBA)•
当然可以,以下是一个 C 语言实现的判断回文的程序:
```c
#include <stdio.h>
#include <string.h>
int is_palindrome(char *s) {
int len = strlen(s);
for (int i = 0; i < len / 2; i++) {
if (s[i] != s[len - i - 1])
return 0; // 不是回文
}
return 1; // 是回文
}
int main() {
char s[100];
printf("请输入一个字符串:");
scanf("%s", s);
if (is_palindrome(s))
printf("是回文\n");
else
printf("不是回文\n");
return 0;
}
```
上述代码使用 `is_palindrome` 函数来判断一个字符串是否是回文。函数接收一个指向字符串的指针,并返回一个整数值,表示这个字符串是否是回文。在函数内部,我们使用循环遍历字符串的前一半,逐个比较对应位置的字符是否相同,如果不相同,则说明这个字符串不是回文。
在 `main` 函数中,我们从用户输入中获取一个字符串,并调用 `is_palindrome` 函数来判断它是否是回文。根据函数的返回值,我们打印出相应的结果。
希望这可以帮助到你!
阅读全文