Java 程序:显示两个区间之间的阿姆斯特朗数
要理解此示例,您应该具备以下 Java 编程 主题的知识:
一个正整数被称为 n
阶阿姆斯特朗数,如果它满足以下条件:
abcd... = an + bn + cn + dn + ...
在 3 位数的阿姆斯特朗数的情况下,每个数字的立方和等于该数字本身。例如:
153 = 1*1*1 + 5*5*5 + 3*3*3 // 153 是一个阿姆斯特朗数。
此程序基于如何检查一个整数是否为阿姆斯特朗数的概念构建。
示例:两个整数之间的阿姆斯特朗数
class Main {
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;
// result 包含其数字的 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
在上述程序中,检查了给定区间 high 和 low 之间的每个数字。
每次检查后,数字的 digits
和和数 result
都被重置为 0。