笔试题--“完数”(4)

来源:互联网 发布:淘宝付款不发货骗术 编辑:程序博客网 时间:2024/04/30 12:16
/**
 * 一个数如果恰好等于它的因子之和,这个数就称为"完数"。
 * 例如6=1+2+3。查找出所有大于1小于等于整数m(m < 10000)的完数。
 *  例如,若输入:1000,则应输出:6 28 496。
 */
import java.util.Scanner;


public class SearchWanShu {


    public static void main(String[] args) {
        Scanner in= new Scanner(System.in);
        int num=in.nextInt();
        new SearchWanShu().search(num);
        in.close();
    }
    
    public void search(int num){
        
        if(num<=10000&&num>1){
            for(int i=2;i<num;i++){
                
                int he=0;
                for(int j=i-1;j>=1;j--){


                    if(i%j==0){
                        he+=j;
                    }
                }
                if(i==he){
                    System.out.print(i+" ");
                }
            }
        }
        else{
           System.out.println("error"); 
        }
    }


}
0 0
原创粉丝点击