原文: https://www.programiz.com/kotlin-programming/examples/armstrong-number-interval

在此程序中,您将学习在 Kotlin 中显示两个给定间隔(低和高)之间的所有阿姆斯特朗数字。

一个正整数称为阿姆斯特朗数n,如果

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

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

  1. 153 = 1*1*1 + 5*5*5 + 3*3*3 // 153 is an Armstrong number.

该程序基于的概念,该方法如何检查整数是否为阿姆斯特朗数

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

  1. fun main(args: Array<String>) {
  2. val low = 999
  3. val high = 99999
  4. for (number in low + 1..high - 1) {
  5. var digits = 0
  6. var result = 0
  7. var originalNumber = number
  8. // number of digits calculation
  9. while (originalNumber != 0) {
  10. originalNumber /= 10
  11. ++digits
  12. }
  13. originalNumber = number
  14. // result contains sum of nth power of its digits
  15. while (originalNumber != 0) {
  16. val remainder = originalNumber % 10
  17. result += Math.pow(remainder.toDouble(), digits.toDouble()).toInt()
  18. originalNumber /= 10
  19. }
  20. if (result == number)
  21. print("$number ")
  22. }
  23. }

运行该程序时,输出为:

  1. 1634 8208 9474 54748 92727 93084

在上述程序中,检查了给定间隔高和低之间的每个数字。

每次检查后,digits的位数和总和result被恢复为 0。