用c语言编程判断一个整数是否为自守数
时间: 2023-09-16 19:11:07 浏览: 142
好的,以下是用C语言编写的判断一个整数是否为自守数的程序:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main() {
int n;
printf("请输入一个整数:\n");
scanf("%d", &n);
// 计算该数的平方
long long square = (long long)n * n;
// 将该数和它的平方转换成字符串
char str1[20], str2[20];
sprintf(str1, "%d", n);
sprintf(str2, "%lld", square);
// 比较末尾数是否相等
int len1 = strlen(str1), len2 = strlen(str2);
if (len1 > len2) {
printf("不是自守数\n");
return 0;
}
for (int i = 1; i <= len1; i++) {
if (str1[len1 - i] != str2[len2 - i]) {
printf("不是自守数\n");
return 0;
}
}
printf("是自守数\n");
return 0;
}
```
该程序首先让用户输入一个整数,然后计算该数的平方,并将该数和它的平方转换成字符串。接着,该程序比较两个字符串的末尾数是否相等,如果相等则输出“是自守数”,否则输出“不是自守数”。注意,为了避免整数溢出,该程序使用了long long类型来保存平方。
阅读全文