题目:
第7章实验任务5
如果一个正整数m的所有小于m的不同因子(包括1)加起来正好等于m本身,那么就被称它为完全数。它是指这样的一些特殊的自然数,它所有的真因子(即除了自身以外的约数)的和,恰好等于它本身。
注意:1没有真因子,所以不是完全数。例如,6就是一个完全数,是因为6 = 1 + 2 + 3。
请编写一个判断完全数的函数IsPerfect(),然后判断从键盘输入的整数是否是完全数。
要求:按如下原型编写判断完全数的函数,若函数返回0,则代表不是完全数,若返回1,则代表是完全数。
int IsPerfect(int x);
**要求输入提示信息为: "Input m:\n"
**要求输入格式为: "%d"
**要求输出格式为
"%d is a perfect number\n"
"%d is not a perfect number\n"
注:不能使用指针、结构体、共用体、文件、goto、枚举类型进行编程。
代码如下:
#include <stdio.h>
int IsPerfect(int x);//声明函数
int main()
{
int m,flag;
printf("Input m:\n");
scanf("%d",&m);
flag=IsPerfect(m);//判断m是否是完全数
if(flag)//函数返回值为真的话就是完全数
{
printf("%d is a perfect number\n",m);
}
else
{
printf("%d is not a perfect number\n",m);
}
}
int IsPerfect(int x)
{
int sum=0;
for(int i=1;i<=x/2;i++)
{
if(x%i==0)
{
sum+=i;
}
}
if(x==sum)//如果m的数值和她的因子的总和相等,返回1;反之返回0
{
return 1;
}
else return 0;
}
运行结果:
欢迎交流