c语言判断是否是回文数
时间: 2024-11-02 09:07:04 浏览: 43
在 C 语言中,判断一个整数是否是回文数通常是指从前往后读和从后往前读是一样的数字。下面是一个简单的函数示例,用于检查输入的整数 `num` 是否是回文:
```c
#include <stdio.h>
#include <stdbool.h>
bool isPalindrome(int num) {
if (num < 0) { // 负数不是回文
return false;
}
int reversed = 0; // 反转后的数字
while (num != 0) {
int digit = num % 10; // 取最后一位数字
reversed = (reversed * 10) + digit; // 将新数字加到反转数上
num /= 10; // 移除最后一位
}
return reversed == num; // 如果反转后的数字等于原数,则是回文
}
int main() {
int input;
printf("请输入一个整数:");
scanf("%d", &input);
if (isPalindrome(input)) {
printf("%d 是回文数。\n", input);
} else {
printf("%d 不是回文数。\n", input);
}
return 0;
}
相关问题
c语言判断是否为回文
在C语言中,判断一个字符串是否是回文(即正读反读都一样)的一种常见方法是通过比较字符串的前半部分与它的后半部分。这里是一个简单的函数示例:
```c
#include <stdio.h>
#include <string.h>
int isPalindrome(char str[]) {
int len = strlen(str);
if (len <= 1) { // 如果字符串长度为0或1,它是回文的
return 1;
}
// 比较首尾字符是否相等,然后向中间移动
for (int i = 0; i < len / 2; i++) {
if (str[i] != str[len - 1 - i]) {
return 0; // 字符不匹配,不是回文
}
}
return 1; // 所有字符匹配,是回文
}
int main() {
char test[] = "madam";
if (isPalindrome(test)) {
printf("%s is a palindrome.\n", test);
} else {
printf("%s is not a palindrome.\n", test);
}
return 0;
}
```
c语言判断是否为回文串
判断一个字符串是否为回文串可以使用双指针的方法,具体实现如下:
```
#include <stdio.h>
#include <string.h>
int main()
{
char str[100];
int len, i, j, flag;
printf("Enter a string: ");
scanf("%s", str);
len = strlen(str);
flag = 1;
for (i = 0, j = len - 1; i < j; i++, j--)
{
if (str[i] != str[j])
{
flag = 0;
break;
}
}
if (flag)
printf("%s is a palindrome\n", str);
else
printf("%s is not a palindrome\n", str);
return 0;
}
```
该程序先读入一个字符串,然后使用双指针分别从字符串的开头和结尾向中间移动,如果指向的字符不相同,则不是回文串。最后判断标志位来输出结果。
阅读全文