网站建设资讯

NEWS

网站建设资讯

C语言中用函数求完数 c语言中取余数

C语言求完数

#include stdio.h

我们提供的服务有:成都网站制作、成都网站建设、外贸营销网站建设、微信公众号开发、网站优化、网站认证、平度ssl等。为上千多家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的平度网站制作公司

int ws(int a,int b,int c)

{

int d;

if (ac) {

if (a%c==0)

b+=c;

d=ws(a,b,c+1);

}

else if (c==a) {

if (b==a) {

return 1;

}

else return 0;

}

if (c==a-1d) {

printf("%d is Prefect number:\t",a);

}

if (d(a%c==0)) {

printf("%d ",c);

}

else if (!d) return 0;

if (c==1)

{putchar('\n');

return d;}

}

int main(void)

{

int i;

for (i=1; i=1000; i++)

ws(i,0,1) ;

return 0;

}

这里举例了一个求1000以内的完数算法,供你参考

用C语言求1000以内的完数?

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

根据该定义 可以得出判断完数的函数如下:

#include stdio.h

int is_perfect_number(int n)

{

int i,s=0;

for(i = 1; i =n/2; i ++)

if(n%i == 0) s+= i;//统计所有真因子的和。

if(s == n) return 1;//如果与原值相等,则该数为完数。

return 0;//不是完数。

}

根据该函数,只需要对需要打印的范围内1 ~1000做遍历,并逐一调用该函数判断,如果返回1则打印即可。

完整代码如下:

#include stdio.h

int is_perfect_number(int n)

{

int i,s=0;

for(i = 1; i =n/2; i ++)

if(n%i == 0) s+= i;//统计所有真因子的和。

if(s == n) return 1;//如果与原值相等,则该数为完数。

return 0;//不是完数。

}

int main()

{

int n;

for(n = 1; n 1000; n++)

if(is_perfect_number(n)) printf("%d,",n);

}

c语言用函数输出完数

#includestdio.h

int main()

{

int i,n,sum;

int a,b;

scanf("%d%d",a,b);

for(n=a;n=b;n++)

{

sum=0;

for(i=1;in;i++)

{

if(n%i==0)

{sum=sum+i;}

}

if(sum==n)

{printf("%4d",n);}

}

return 0;

}

c语言 调用函数,求m-n之间的所有完数

#includestdio.h 

int factorsum(int n)

{

int i,sum=0;

for(i=1;in;i++)

{

if(n%i==0)

sum+=i;

}

return sum; 

}

int main()

{

int n,m,i,flag;

while(scanf("%d%d",m,n)!=EOF)

{

flag =1;

for(i=m;i=n;i++)

{

if(i==factorsum(i))

{

if(flag)

{

printf("%d",i);

flag=0;

}

else

{

printf(" %d",i);

}

}

}

printf("\n");

}

return 0;

}

扩展资料:

注意事项

1、每一个完全数都可以表示成连续自然数的和

每一个完全数都可以表示成连续自然数的和,这些自然数并不一定是完全数的因数。例如:

6=1+2+3 28=1+2+3+4+5+6+7

496= 1+2+3+4+. • -+29+30+31

2、每一个完全数都是调和数

我们知道,如果一个正整数的所有因子的调和平均是整数,那么这个正整数便是调和数。而每 一个完全数都是调和数,例如: 对于完全数6 来说,1/1+1/2+1/3+1/6=2 对于完全数28来说,1/1+1/2+1/4+1/7+1/14+1/28=2 3 . 每一个完全数都可以表示为2 的一些连续正整数次幂之和 每一个完全数都可以表示为2 的一些连续正整数次幂之和,例如: 6=2^l+2^2

28=2^2+2^3+2^4

8128=2^6+2^7+2^8+2^9+2^10+2^11 +2^ 12


网页标题:C语言中用函数求完数 c语言中取余数
转载源于:http://cdweb.net/article/hgsheh.html