在此程序中,您将学习在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
//结果包含其数字的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
在上述程序中,检查了给定间隔高和低之间的每个数字。
每次检查后,digits和result将恢复为0。