所谓完数就是该数恰好等于除自身外的因子之和。例如:6=1+2+3,其中1、2、3为6的因子。本题要求编写程序,找出任意两正整数m和n之间的所有完数。
输入格式:
输入在一行中给出2个正整数m和n(1<m≤n≤10000),中间以空格分隔。
输出格式:
逐行输出给定范围内每个完数的因子累加形式的分解式,每个完数占一行,格式为“完数 = 因子1 + 因子2 + … + 因子k”,其中完数和因子均按递增顺序给出。若区间内没有完数,则输出“None”。
输入样例:
2 30
输出样例:
6 = 1 + 2 + 3
28 = 1 + 2 + 4 + 7 + 14
import java.util.Scanner;
public class Main {
public static void main(String[] agrs) {
Scanner hey=new Scanner(System.in);
int m=hey.nextInt();
int n=hey.nextInt();
int i,j,sum,flag=0;
for(i=m;i<=n;i++)
{ if(i==1) continue;
sum=1;
for(j=2;j<i;j++)
{
if(i%j==0)
sum=sum+j;
}
if(sum==i)
{
flag=1;
System.out.printf("%d = 1",sum);
for(j=2;j<i;j++)
{if(i%j==0)
System.out.printf(" + %d",j);
}hey.close();System.out.println( );
}
}
if(flag==0)
System.out.println("None");
}}
求一段范围内的完数。思路就是遍历这段范围,判断其他因数相加是否等于它本身,等于的话,再依次输出。出现运行超时的结果有可能是使用完Scanner没有及时关闭,最好用完就关掉。还有一个要注意的点就是每次用完sum之后在下次使用之前要把sum赋值为一。
新手入门,写的不好,请多指教。