如果一个正整数等于它的除数之和,那么这个数被称为完美数(perfect number),例如 6 = 1 + 2 + 3,28 = 1 + 2 + 4 + 7 + 14,像这样 6 和 28 都是完美数。如果一个数不是完美数那么他是不完美数,不完美数又分为不充足的(deficient)和过充足的(abundant)。例如 9 的除数有 1 + 3 = 4 ,9 是不充足的,12 的除数有 1 + 2 + 3 + 4 + 6 = 16,12 是过充足的。 你的任务是给定一个数判断其是完美数、过充足的还是不充足的。
Input
N (1 < N < 100)个不大于 60,000 的正整数,输入 0 结束输入
Output
第一行输出 PERFECTION OUTPUT 。 接下来 N 行 输出 N 个数是完美数、过充足的还是不充足的(参考输出样例)。每个数字使用五个空格左对齐,然后输出两个空格,最后输出这个数字的属性。 最后一行输出 END OF OUTPUT。
Sample Input
15 28 6 56 60000 22 496 0
Sample Output
PERFECTION OUTPUT 15 DEFICIENT 28 PERFECT 6 PERFECT 56 ABUNDANT 60000 ABUNDANT 22 DEFICIENT 496 PERFECT END OF OUTPUT
#include<stdio.h>
#include<string.h>
int main()
{
int n;
int a[1000];
int c = 0;
while (scanf("%d", &n) != EOF && n != 0)
{
if (c == 0)
{
printf("PERFECTION OUTPUT\n"); //程序第一次运行时输出
}
c++;
if (n < 10)
{
printf(" ");
}
if(n>=10&&n<100)
{
printf(" ");
}
if(n>=100&&n<1000)
{
printf(" ");
}
if (n >= 1000 && n < 10000)
{
printf(" ");
}
//实现右对齐,可以直接用%5d
printf("%10dOK\n", 8888); //右对齐。数字宽度为10,若不足10,在左边补足空格
printf("%-10dOK\n", 8888); //左对齐。数字宽度为10,若不足10,在右边补足空格
printf("%d ", n);
int i,j=0,k,sum=0;
for (i = 1; i < n; i++)
{
if (n%i == 0)
{
a[j++] = i;
}
}
for (k = 0; k < j; k++)
{
sum = sum + a[k];
}
if (sum == n)
{
printf("PERFECT\n");
}
if (sum < n)
{
printf("DEFICIENT\n");
}
if (sum > n)
{
printf("ABUNDANT\n");
}
}
printf("END OF OUTPUT\n");
return 0;
}
修改后
#include<stdio.h>
#include<string.h>
int main()
{
int n;
int a[1000];
int c = 0;
while (scanf("%d", &n) != EOF && n != 0)
{
if (c == 0)
{
printf("PERFECTION OUTPUT\n");
}
c++;
printf("%5d ", n);
int i, j = 0, k, sum = 0;
for (i = 1; i < n; i++)
{
if (n%i == 0)
{
a[j++] = i;
}
}
for (k = 0; k < j; k++)
{
sum = sum + a[k];
}
if (sum == n)
{
printf("PERFECT\n");
}
if (sum < n)
{
printf("DEFICIENT\n");
}
if (sum > n)
{
printf("ABUNDANT\n");
}
}
printf("END OF OUTPUT\n");
return 0;
}