温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

求1000以内的所有完数

发布时间:2020-08-11 12:04:01 来源:网络 阅读:4727 作者:五子连星 栏目:编程语言
static void Main(string[] args)
{
    //求1-1000内所有的完数
    //完全数,又称完美数或完备数,是一些特殊的自然数:它所有的真因子(即除了自身以外的约数)的和,恰好等于它本身。例如6: 6=1+2+3
    //真因子,是所有可以整除这个数的数,但是不包括这个数自身
                
    //遍历1到1000
    for (int i = 1; i <= 1000; i++)
    {
        int sum = 0;    //定义一个变量用来存储一个数的所有因子的和
        //遍历一个数的真因子
        //一个整数的真因子都小于或等于这个数的一半,所有只需要遍历到i/2
        for (int j = 1; j <= i/2; j++)
        {
            if (i % j == 0) //判断是否可以被整除,可以即为真因子
            {
                sum += j; //所有真因子的和
            }
        }
        if (i == sum) //判断整数是否等于它所有真因子的和
        {
            Console.WriteLine(i + "是一个完数");
        }               
    }
    Console.ReadKey();
}

结果是:6、28、496。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI