判断一个数是否为回文数的一种简单方法是将该数转化为字符串,然后比较字符串的前一半与后一半是否相等。具体步骤如下:
以下是一个使用该方法判断回文数的示例代码:
#include <stdio.h>
#include <stdbool.h>
#include <string.h>
bool isPalindrome(int num) {
char str[20]; // 假设数的最大位数不超过20
sprintf(str, "%d", num); // 将数转化为字符串
int len = strlen(str);
int mid = len / 2;
for (int i = 0; i < mid; i++) {
if (str[i] != str[len - 1 - i]) {
return false;
}
}
return true;
}
int main() {
int num;
printf("请输入一个整数:");
scanf("%d", &num);
if (isPalindrome(num)) {
printf("%d是回文数\n", num);
} else {
printf("%d不是回文数\n", num);
}
return 0;
}
注意:上述代码假设数的最大位数不超过20,可以根据实际需求调整数组str
的大小。另外,上述方法可以处理负数情况,例如对于输入的数-121,仍会判断为回文数。