黑马程序员技术交流社区

标题: 完数 [打印本页]

作者: 终极黑马    时间: 2015-7-14 21:59
标题: 完数
/*
* 需求:题目:一个数如果恰好等于它的因子之和,这个数就称为"完数"。
*     例如6=1+2+3.编程找出10000以内的所有完数。
*
* 思路:循环查找i内能被整除的数,循环次数i / 2 + 1,把这些能整除的数加起来,如果==i就打印i。
* */
public class Test1 {
        public static void main(String[] args) {
                int n = 10000;
                System.out.print(n + "以内的完数:");
                for (int i = 1; i < n + 1; i++) {
                        int sum = 0;
                        for (int j = 1; j < i / 2 + 1; j++) {
                                if ((i % j) == 0) {
                                        sum += j;
                                }
                        }
                        if (sum == i)
                                System.out.print(i + " ");

                }
        }
}






欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2