完数?
时间限制:
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,i,j,sum; int a[10000]; while(scanf("%d",&n)!=EOF) { if(n==-1) break; else { sum=0; if(n==1||n==2) printf("No\n"); else { for(i=1,j=0;i<=n/2;i++) { if(n%i==0) { a[j++]=i; sum+=i; } } if(sum!=n) printf("No\n"); else { printf("%d=%d", n, a[0]); for (i = 1; i < j; i++) { printf("+%d", a[i]); } printf("\n"); } } } } return 0; }
-
每组数据输入一个n(1<=n<=10^4)