判断一个数是否为回文数的一种简单方法是将该数转化为字符串,然后比较字符串的前一半与后一半是否相等。具体步骤如下:
以下是一个使用该方法判断回文数的示例代码:
#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,仍会判断为回文数。