/*完全数(Perfect number),又称完美数或完备数,是一些特殊的自然数。它所有的真因子(即除了自身以外的约数)的和(即因子函数),恰好等于它本身。

本关任务:编写一个能判断某数是否是完数的函数;
输入一个数x,输出1-x以内的完数。*/
/*---------begin-----------------*/
//judgePerfect函数用于判断参数data是否是完数,返回值1表示是,0表示不是

代码如下:

#include<stdio.h>
int judgePerfect(int data) {
	int i,j;
	int s=0;
	for(j=1; j<data; j++) {
		if((data%j)==0) {
			s+=j;
		}
	}
	if(s==data) {
		return 1;
	} else {
		return 0;
	}
}



//编写主函数调用judgePerfect函数,输出100以内的所有完数,每输出5个数换一行,两个数字之间用逗号隔开
int main(void) {
	int n;
	scanf("%d",&n);
	int i;
	int count=0;
	int flag = 0;
	for(i=1; i<n; i++) {
		flag = judgePerfect(i);
		if(flag==1) {
			printf("%d,",i);
			count++;
			if(count%5==0) {
				printf("\n");
			}
		}

	}
}

 

 

更多推荐

用C语言实现完全数的求解(附有详细代码)