7-38 水仙花数 (20 分)
水仙花数是指一个N位正整数(N≥3),它的每个位上的数字的N次幂之和等于它本身。例如:153=13+53+33。 本题要求编写程序,计算所有N位水仙花数。
输入在一行中给出一个正整数N(3≤N≤7)。
按递增顺序输出所有N位水仙花数,每个数字占一行。
3
153
370
371
407
package demo;
import java.util.Scanner;
public class Main {
public static void main(String[] args){
int n=0; //输入一个整数
Scanner sr = new Scanner(System.in);
n=sr.nextInt();
int x=0;
for(x=(int) Math.pow(10,n-1);x<(Math.pow(10,n));x++){ //从他的位数除10开始计算
int b=(int) x; // 保存x的值
int sum=0,a=0,i;
for(i=1;i<=n;i++){
a=b%10; //a是x的最后一位
b/=10; //b不断除以10,以取得最后一位
sum+=Math.pow(a,n); // 循环相加每一个位数的相应的次方
}
if(sum==x)
{
System.out.println(x);
}
}
}
}