当前位置:首页 » 编程语言 » c语言求完数的编程
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言求完数的编程

发布时间: 2022-09-13 04:23:58

① 用c语言编程:输出2~100之间所有完数,完数是指该数各因子之和等于该数本身

C语言程序如下:

#include <stdio.h>

int main()

{

long int i,j,sum;

for(i=2;i<100;i++)

{ sum=0;

for(j=2;j<=i/2;j++)

{

if(i%j==0)

{

sum=sum+j;

}

}

if(i==sum+1)

printf("%d ",i);

}

}

(1)c语言求完数的编程扩展阅读:

如果一个数恰好等于它的因子之和,则称该数为“完全数”。

第一个完全数是6,它有约数1、2、3、6,除去它本身6外,其余3个数相加,1+2+3=6。

第二个完全数是28,它有约数1、2、4、7、14、28,除去它本身28外,其余5个数相加,1+2+4+7+14=28。

第三个完全数是496,有约数1、2、4、8、16、31、62、124、248、496,除去其本身496外,其余9个数相加,1+2+4+8+16+31+62+124+248=496。后面的完全数还有8128、33550336等等。

② C语言编程:输出10000以内所有的完数

可以定义一个结构,其中的数据成员有:int型变量s,用以存储各因数的和值;int型数组ys,长度为64,用于存储各因数的值;还有一个int型变量c,用于存储因数的个数。然后定义一个函数,该函数的返回值类型为这个结构,输入参数为一int型待判断正数。函数的内部,一开始,定义一个结构变量,并对它的s和c初始化为0,然后,进行一个用于查找各因数的循环,找到一个,就将它累加到和值变量s,然后将这个因数存储到结构的ys数组的c元素中,接着对c进行加一操作,函数体最后,返回定以被赋值了的结构变量。。。。。接下来就是在主函数main中,调用该函数,具体步骤不再详述,见配图。

运行结果

③ c语言编程:求(2,2000)中的完数

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

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

#include<stdio.h>
intis_perfect_number(intn)
{
inti,s=0;
for(i=1;i<=n/2;i++)
if(n%i==0)s+=i;//统计所有真因子的和。
if(s==n)return1;//如果与原值相等,则该数为完数。

return0;//不是完数。
}

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

完整代码如下:

#include<stdio.h>
intis_perfect_number(intn)
{
inti,s=0;
for(i=1;i<=n/2;i++)
if(n%i==0)s+=i;//统计所有真因子的和。
if(s==n)return1;//如果与原值相等,则该数为完数。

return0;//不是完数。
}

intmain()
{
intn;
for(n=3;n<2000;n++)
if(is_perfect_number(n))printf("%d,",n);
}

④ C语言程序设计 求完数

#include<stdio.h>
#include<math.h>
intw(intx)
{
inti,sum=1;
for(i=2;i<=sqrt(x);i++)
{
if(x%i==0)
{
sum+=i+x/i;
}
}
if(sum==x&&x!=1)
{
return1;
}
else
{
return0;
}
}
intmain()
{
inti,n,m,a[10],j;
scanf("%d%d",&n,&m);
for(i=n,j=0;i<=m;i++)
{
if(w(i))
{
a[j++]=i;
}
}
if(j==0)
{
printf("NIL ");
}
else
{
for(i=0;i<j;i++)
{
if(i<j-1)
{
printf("%d",a[i]);
}
else
{
printf("%d",a[i]);
}
}
}
return0;
}

⑤ c语言求解完数!

#include<stdio.h>
int main()
{
int i,j,sum=0;
int count=0;//计算完数的和
for(i=2;i<1000;i++)
{
for(j=1;j<i;j++)
{
if(i%j==0) sum=sum+j;
}
if(sum==i)
{
printf("%d 是完数\n",i);
count+=i;
}
sum=0;
}

printf("完数和为: %d\n",count);
return 0;
}

⑥ 用C语言:求完数

//因为没有说明结束条件,所以暂且以范围为输入两个0为结束条件
#include<stdio.h>
int check(int low, int high);//打印low和high范围内的完数,并返回完数的个数
int test(int n);//检测n是否为完数,如果是,则打印它,并返回1,否则,返回0.
int main(){
int low, high;
int count;//count变量为low和high范围内的完数个数
scanf("%d%d", &low, &high);//输入范围
if(low>high || high>10000)//若不满足要求的条件,退出程序
return (1);
while(low!=0 || high!=0)//low和high均为0,则结束
{
count=check(low, high);//打印low和high之间的完数,并返回个数给count
if(count==0)//如果完数个数为0,则打印no
printf("no");
printf("\n");
scanf("%d%d", &low, &high);//重新输入范围low和high
}
return 0;
}
int check(int low, int high){
int t=0;//t为发现的完数个数
int n;
for(n=low;n<=high;n++)
{
if(test(n)==1)
t++;
}
return t;//返回完数个数
}
int test(int n)
{
int i;
int sum=0;//sum为因子之和
for(i=1;i<=n/2;i++)
if(n%i==0)
sum=sum+i;
if(sum==n)
{
printf("%d ", n);//若n为完数,则打印,并返回1
return 1;
}
else//否则,返回0
{
return 0;
}
}
希望对你有用~~

⑦ 求完数的c语言程序

//一个数如果恰好等于它的因子之和,这个数就称为"完数"。编程找出1000以内的所有完数。
#include <stdio.h>
int* ss(int);//求正整数的质因数
void main()
{
int i,sum=1,j,*a;
for(i=6;i<1000;i++)
{
a=ss(i);
for(j=0;j<500;j++,a++)
sum+=*a;
if(sum==i)
printf("%d\n",i);
}
}
int* ss(int n)
{
int k=2,sum=1,i=0,a[500]={0};
//printf("Please enter a num:\n");
//scanf("%d",&n);
while(n>=k)
{
if(n==k)
{
//printf("%d\n",k);
a[i++]=k;
break;
}
else
if(n%k==0)
{
//printf("%d\n",k);
a[i++]=k;
n/=k;
}
else
if(n%k!=0)
k+=1;
};
return a;
}

⑧ 用C语言编程求完数

那叫完全数,这题可以用三重循环解决,外环一个一个找数,内环试验是否全部能整除,中环试验加起来是不是那个数,麻烦得很

⑨ C语言求完数

#include <stdio.h>

int ws(int a,int b,int c)
{
int d;
if (a>c) {
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-1&&d) {
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语言求完数的程序

#include<stdio.h>
void main()
{
int m,s,i;
for(m=2;m<1000;m++)
{
s=0;
for(i=1;i<m;i++)
if((m%i)==0)s=s+i;
if(s==m)
{printf("%d=",m);
for(i=1;i<m;i++)
if(m%i==0 && i==1) printf("%d",i); /* 修改 */
elseif(m%i==0)printf("+%d",i); /* 添加 */
printf("\n");
}
}
}