c语言求小于n的自守数
时间: 2024-10-25 10:08:45 浏览: 34
在C语言中,求解小于某个整数n的自守数(Palindrome Number),是指一个正整数等于它的各位数字反转后的数。例如,121和656都是自守数。要编写程序来找出所有的自守数,你可以采用以下步骤:
1. 定义一个函数,比如`is_palindrome()`,检查输入的数是否为自守数。这个函数可以接受一个整数作为参数,并将其转换为字符串,然后比较原数和字符串反转后的数是否相等。
```c
#include <stdio.h>
#include <stdbool.h>
#include <string.h>
bool is_palindrome(int num) {
char str[100];
int len = snprintf(str, sizeof(str), "%d", num);
return strcmp(str, str[len - 1] == '\0' ? str : str + len - 1) == 0;
}
```
2. 写主函数,遍历从1到n-1的所有整数,对于每一个数,调用`is_palindrome()`判断其是否为自守数。
```c
int main() {
int n;
printf("请输入一个整数n:");
scanf("%d", &n);
for (int i = 1; i < n; ++i) {
if (is_palindrome(i)) {
printf("%d ", i); // 打印找到的自守数
}
}
return 0;
}
```
阅读全文