java面试题目-完全数
* 问题描述:若一个自然数,它所有的真因子(即除了自身以外的约数)的和恰好等于它本身,这种数叫做完全数。简称“完数”
例如,
6=1+2+3
28=1+2+4+7+14
496=1+2+4+8+16+31+62+124+248
8128=1+2+4+8+16+32+64+127+254+508+1016+2032+4064
* 程序输出:编写一个Java程序,输出任意数之间的所有完数。
* 问题分析:求一个数的回文数,要求这个数的约数相加之和等于本身。
* 算法设计:首先要定义求所求数的约数的函数,然后将约数相加,再与其本身比较,判断结果。。。
*/
1 public class TestComNum { 2 3 /** 4 * @param args 5 */ 6 public static void main(String[] args) { 7 // TODO Auto-generated method stub 8 printComNum(1000); 9 } 10 static void printComNum(int n){ 11 for(int i = 1; i <= n;i++){ 12 int s = 0; 13 for(int j = 1;j < i;j++){ 14 if(i % j == 0){ 15 s = s + j; 16 } 17 } 18 if(s == i){ 19 System.out.println(i+"是完全数..."); 20 } 21 } 22 } 23 }
运行结果:
6是完全数...
28是完全数...
496是完全数...
经验积累:从现在起养成良好的变成习惯,不要忙着敲代码,分析问题和构建框架更重要!!!
浙公网安备 33010602011771号