跳到主要内容

Kotlin 程序显示两个间隔之间的阿姆斯特朗数

如果一个正整数满足以下条件,则称其为阶数为n的阿姆斯特朗数:

abcd... = an + bn + cn + dn + ...

对于一个3位数的阿姆斯特朗数,每个数字的立方和等于该数字本身。例如:

153 = 1*1*1 + 5*5*5 + 3*3*3  // 153是阿姆斯特朗数。

这个程序是基于如何检查一个整数是否是阿姆斯特朗数的概念构建的。

示例:两个整数之间的阿姆斯特朗数

fun main(args: Array<String>) {
val low = 999
val high = 99999

for (number in low + 1..high - 1) {
var digits = 0
var result = 0
var originalNumber = number

// 计算数字的位数
while (originalNumber != 0) {
originalNumber /= 10
++digits
}

originalNumber = number

// result包含其数字的n次幂的和
while (originalNumber != 0) {
val remainder = originalNumber % 10
result += Math.pow(remainder.toDouble(), digits.toDouble()).toInt()
originalNumber /= 10
}

if (result == number)
print("$number ")
}
}

当您运行该程序时,输出将是:

1634 8208 9474 54748 92727 93084

在上面的程序中,检查了给定区间low和high之间的每个数字。

在每次检查后,数字的位数digits和和result都被重置为0。