完美数

如果一个正整数等于它的除数之和,那么这个数被称为完美数(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;
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值