输入一个正整数求所有素数因子_一个数如果恰好等于它的因子之和,这个数就称为完数。编写应用程序求1000以内所有的完数...

运行截图:

239c0b2a6485cca36ada2ea5b32d54da.png

代码

import java.util.*;

public class wanshu {

public static void main(String args[])  {

int sum = 0,i,j,k,m = 0;

System.out.println(" 完数有:");

for( j = 2; j <= 1000 ; j++)

  {

     for ( i = 2 ; i <= j; i++)

       {

if( j%i == 0)      //此判断是为了判断是否能够被整除

                 {

    k = j/i;

    m = m + k;

        }

}

      if ( m == j )

       System.out.println(" "+j);

         m = 0;

}

}

}

注意一下这个判断

if( j%i == 0)      //此判断是为了判断是否能够被整除

                 {

    k = j/i;

    m = m + k;

        }

}

这个判断是不能省略的,想必大家都知道,java中如果不能被整除,那当中k的值是除去小数部分的整数,也就是说,如果省略if判断后,假如代码中j的值为5,i的值为2那么k的值将会是2;但是5/2不是整数,所以不符合完数的定义。

刚开始学java,接下来我也会持续更新java的题目,督促自己学习,以后的文章都会写一下关于自己对代码的理解,以及写一下自己认为容易出错的地方。

欢迎关注我的csdn账号:用户名: 什么都不懂的大佬

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值