| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 738 人关注过本帖
标题:[求助]求助:一个关于完数的编程!
只看楼主 加入收藏
lqmqj
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2007-9-15
收藏
 问题点数:0 回复次数:2 
[求助]求助:一个关于完数的编程!

题目:
如果一个数的因子之和等于它本身,这个数就叫完数,如6=1+2+3,1,2,3是6的因子,编程输出1000以内的完数.
主要求教一下算法.

搜索更多相关主题的帖子: 编程 
2007-09-20 19:32
HK狼
Rank: 1
等 级:新手上路
威 望:1
帖 子:46
专家分:0
注 册:2007-9-9
收藏
得分:0 
main()
{
static int k[10];
int i,j,n,s;
for(j=2;j<1000;j++)
{
n=-1;
s=j;
for(i=1;i<j;i++)
{
if((j%i)==0)
{
n++;
s=s-i;
k[n]=i;
}
}
if(s==0)
{
printf("%d is a wanshu",j);
for(i=0;i<n;i++)
printf("%d,",k[i]);
printf("%d\n",k[n]);
}
}
system("pause");
}

2007-09-20 20:16
etherli
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2007-9-14
收藏
得分:0 

我这也编一个,跟楼上的差不多,都是用穷举法.
#include<iostream.h>

void main()
{
for(int i=2;i<1000;i++)
{
int sum=0;
for(int j=1;j<i;j++)
{
if(i%j==0)
sum+=j;
}
if(sum==i)
cout<<i<<" ";
}
cout<<endl;
}

[此贴子已经被作者于2007-9-20 21:48:30编辑过]

2007-09-20 21:47
快速回复:[求助]求助:一个关于完数的编程!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.036719 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved