鱼C论坛

 找回密码
 立即注册
查看: 2081|回复: 3

[已解决]这样写代码可以求出所有完数吗?

[复制链接]
发表于 2018-6-6 17:09:04 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3.编程
   找出1000以内的所有完数

#include "stdio.h"
void main()
{
    int i,sum,j;//sum等于因数之和
    for(i=3;i<=1000;i++)
    {
        sum=1;//重置sum值
        for(j=2;j<i;j++)//求因数
        {
            while(i!=j)
            {
                if(i%j==0)
                {
                   sum+=j;
                   i=i/j;
                }
                else
                {
                    break;
                }
            }
        }
        sum+=i;//因数之和
        if(i==sum)
            {
                printf("perfect number:%d",i);//输出完数
            }
    }
}
最佳答案
2018-6-6 17:15:24
一个数的因子不仅仅是这些,比如
18的因子为1,2,3,6,9,其实还有18,但是根据题意,应该是比自身小的因子

用你的代码求出来的因子为
1,2,3,3,结果sum为9
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-6-6 17:13:14 | 显示全部楼层
我想问下错在哪里?该怎么改?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-6-6 17:15:24 | 显示全部楼层    本楼为最佳答案   
一个数的因子不仅仅是这些,比如
18的因子为1,2,3,6,9,其实还有18,但是根据题意,应该是比自身小的因子

用你的代码求出来的因子为
1,2,3,3,结果sum为9
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-6-6 18:14:48 | 显示全部楼层
BngThea 发表于 2018-6-6 17:15
一个数的因子不仅仅是这些,比如
18的因子为1,2,3,6,9,其实还有18,但是根据题意,应该是比自身小的 ...

哦哦,谢谢提醒
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-29 22:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表