算法——完全数

1.代码实现:

 /**
     * 完全数(Perfect number),又称完美数或完备数,是一些特殊的自然数。
     * 它所有的真因子(即除了自身以外的约数)的和(即因子函数),恰好等于它本身。
     * 如果一个数恰好等于它的因子之和,则称该数为“完全数”。
     * 例如:6=1+2+3;
     * 28=1+2+3+4+5+6+7
     */
    public static void main(String[] args) {
        int i, j;
        int sum;
        //指定范围
        for (i = 2; i < 1000; i++) {
            sum = 0;
            //被除数范围
            for (j = 1; j <= i / 2; j++) {
                //整数因子
                if (i % j == 0) {
                    sum += j;
                }
            }
            //完全数判断
            if (sum == i) {
                print(i);
            }
        }
    }
    //打印因子
    private static void print(int n) {
        System.out.println(n + "的约数(除自身外)");
        for (int i = 1; i <= n / 2; i++) {
            if (n % i == 0) {
                System.out.print(i + " ");
            }
        }
        System.out.println();
    }

2.测试结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值