完数?
时间限制:1000 ms | 内存限制:65535 KB
难度:1
- 描述
-
一个数如果恰好等于不等于它本身的所有因子之和,那么这个数就被称为"完数"。例如,6的因子为1,2,3,而6=1+2+3,因此,6是完数。要求给定一个整数n,请编写程序,确定n是否是完数。
- 输入
- 每组数据输入一个n(1<=n<=10^4)
当n为-1时,输入结束。 输出 - 每组数据输出一行,如果 n 不是完数,输出 No 。
否则,以 n 的因子由小到大相加的形式输出。 样例输入 -
1 2 6 -1
样例输出 -
No No 6=1+2+3
-
#include <stdio.h> int main() { int n; while(scanf("%d",&n),n!=-1) { int s = 0; for(int i = 1; i <= n/2; i++) { if(n % i == 0) s += i; } if(s == n) { printf("%d=1",n); for(int i = 2; i <= s/2; i++) { if(s % i == 0) printf("+%d",i); } printf("\n"); } else { printf("No\n"); } } } -
#include <stdio.h> int main() { int n; while(scanf("%d",&n),n!=-1) { if(n==6||n==28||n==496||n==8128) { printf("%d=1",n); for(int i = 2; i <= n/2; i++) { if(n % i == 0) printf("+%d",i); } printf("\n"); } else { printf("No\n"); } } }
- 每组数据输入一个n(1<=n<=10^4)
248

被折叠的 条评论
为什么被折叠?



