企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
# Kotlin 程序:显示两个间隔之间的阿姆斯特朗数 > 原文: [https://www.programiz.com/kotlin-programming/examples/armstrong-number-interval](https://www.programiz.com/kotlin-programming/examples/armstrong-number-interval) #### 在此程序中,您将学习在 Kotlin 中显示两个给定间隔(低和高)之间的所有阿姆斯特朗数字。 一个正整数称为阿姆斯特朗数`n`,如果 ```kt abcd... = an + bn + cn + dn + ... ``` 对于 3 位的阿姆斯特朗数,每个数字的立方数之和等于数字本身。 例如: ```kt 153 = 1*1*1 + 5*5*5 + 3*3*3 // 153 is an Armstrong number. ``` 该程序基于[的概念,该方法如何检查整数是否为阿姆斯特朗数](/kotlin-programming/examples/armstrong-number "Check Armstrong Number in Kotlin")。 ## 示例:两个整数之间的阿姆斯特朗数 ```kt 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 // number of digits calculation while (originalNumber != 0) { originalNumber /= 10 ++digits } originalNumber = number // result contains sum of nth power of its digits while (originalNumber != 0) { val remainder = originalNumber % 10 result += Math.pow(remainder.toDouble(), digits.toDouble()).toInt() originalNumber /= 10 } if (result == number) print("$number ") } } ``` 运行该程序时,输出为: ```kt 1634 8208 9474 54748 92727 93084 ``` 在上述程序中,检查了给定间隔高和低之间的每个数字。 每次检查后,`digits`的位数和总和`result`被恢复为 0。