1. c语言中求完全数
#include <stdio.h>
#include <math.h>
int main()
{
int a,i;
for(a=1;a<=1000;a++){
int A[100]={0},j;
j=0;
for(i=1;i<a;i++){ //i<sqrt(a) ——》并不是判定质数,需要找出除本身外所有因数
if(a%i==0){ //a/i==0 ——》/是求商,%才是取余
A[j]=i; //A[j]=a ——》A[j]应存储的是a的因数,而不是它本身
j++;
}
}
int n,b;
n=j;
b=a;
for(j=j-1;j>=0;j--){
b=b-A[j];
}
if(b==0){
printf("%d=",a);
for(j=0;j<n-1;j++){
printf("%d+",A[j]);
}
printf("%d\n",A[j]);
}
}
return 0;
}
2. C语言求完全数
#include"stdio.h"
intmain(void)
{
inta,b,sum=0;
for(a=6;a<1000;a++){
sum=0;
for(b=a-1;b>=1;b--)
{
if(a%b==0)sum=sum+b;
}
if(sum==a)
printf("%-4d的因数之和是%d ",a,sum);
}
}
执行结果如下;
有疑问继续追问;如解决您的问题,望采纳;
3. 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以内的完数算法,供你参考
4. C语言求完数
/*完数,即完美数,一个数如果恰好等于除它本身外的因子之和,这个数就称为完数。例如6=1+2+3.(6的因子是1,2,3)*/
#include<stdio.h>
void main()
{
int i,j,k,h,s,sum;
int a[200];//20个是不够的
s=0;
sum=0;
for(i=2;i<=1000;i++)
{
s=0;//此处s=0一定要加,因为前几次循环的时候s的值已经改变
k=0;
for(j=1;j<i;j++)
{
if((i%j)==0){a[k]=j;k++;}
}
for(h=0;h<k;h++)
{
s+=a[h];
}
if(i==s){printf("%d ",i);sum++;}
}
printf("完数的个数:%d\n",sum);
}
时间太紧,没注意程序的简洁性和效率,这个需要你自己改了!
5. c语言求完全数
完全数,又称完美数, 是一些特殊的自然数。它所有的真因子(即除了自身以外的约数的和(即因子函数),恰好等于它本身。如果一个数恰好等于它的真因子之和,则称该数为“完全数”。第一个完全数是6,6=1 2 3=1+2+3.
6. 如何用 C/C++ 求 1 到 1000 内的所有完全数
用 C/C++求1到1000内的所有完全数:
voidWS(int);
voidmain();
intn;
for(n=1;n<=1000;n++);
WS(n);
voidWS(intm);
{inti,sum=0;
for(i=1;i<m;i++);
if(m%i==0);
sum=sum+i;
if(sum==m);
printf(" 完数为%d=",m);
intj;
for(j=1;j<m;j++);
if(m%j==0);
printf("%d",j)。
定义
如果一个数恰好等于它的真因子之和,则称该数为“完全数”。各个小于它的约数的和等于它本身的自然数叫做完全数,又称完美数或完备数。例如:第一个完全数是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。
7. c语言编写程序:求出1-100之间的完全数.所谓完全数是指这样的数,该数刚好等于
#include<stdio.h>
#defineMAX100/*100以内的完全数*/
intmain(void){
intx,temp,sum;/*X表示要判断的数,temp表示数的因子,sum表示因子之和*/
for(x=1;x<=MAX;x++){
sum=0;
for(temp=1;temp<x;temp++){/*判断x能否被temp整除,如果可以,则是因子,进行求和*/
if(x%temp==0)
sum=sum+temp;
}
if(sum==x)/*如果是完数,打印输出*/
printf("%d ",x);
}
putchar(' ');
fflush(stdin);
getch();
return0;
}
运行结果
8. 用C语言求完数
//有三个,6,28,496
#include<stdio.h>
void main()
{
int i,j,k,sum;
for(i=1;i<=1000;i++)
{
sum=0;
for(j=1;j<=i/2;j++)
if(i%j==0) sum+=j;
if(sum==i)
{
printf("%d\t的因子是:",i);
for(j=1;j<=i/2;j++)
if(i%j==0) printf("%d ",j);
printf("\n");
}
}
return;
}
9. C语言求完全数~~
#include<stdio.h>
void isPerfect(int m){ //定义判断一个数是否为完全数的函数isPerfect
int i,sum=0;
for(i=1;i<=m/2;i++){
if(m%i==0){
sum+=i;
}
}
if(sum==m){
printf("你输入的这个数是完全数\n");
}
else
printf("你输入的这个数不是完全数\n");
}
main(){
int a;
printf("请输入一个整数a:\n");
scanf("%d",&a);
isPerfect(a);//调用这个函数
}
10. 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;
}