在此程序中,您将学习在Java中显示两个给定间隔(低和高)之间的所有armstrong数字。
正整数称为n阶的阿姆斯特朗数,如果
abcd... = an + bn + cn + dn + ...
对于3位的阿姆斯特朗数字,每个数字的立方数之和等于数字本身。例如:
153 = 1*1*1 + 5*5*5 + 3*3*3 // 153是一个阿姆斯特朗数。
该程序基于如何检查整数是否为Armstrong数字的概念。
public class Armstrong { public static void main(String[] args) { int low = 999, high = 99999; for(int number = low + 1; number < high; ++number) { int digits = 0; int result = 0; int originalNumber = number; //位数计算 while (originalNumber != 0) { originalNumber /= 10; ++digits; } originalNumber = number; //结果包含其数字的n次幂的和 while (originalNumber != 0) { int remainder = originalNumber % 10; result += Math.pow(remainder, digits); originalNumber /= 10; } if (result == number) System.out.print(number + " "); } } }
运行该程序时,输出为:
1634 8208 9474 54748 92727 93084
在上述程序中,检查了给定间隔高和低之间的每个数字。
每次检查后,digits和result将恢复为0。