查找两个数字之间的阿姆斯特朗数的 Java 程序

在本程序中,您将学习在 Java 中显示两个给定数字之间的所有阿姆斯特朗数。

要理解此示例,您应该具备以下 Java 编程的知识:

如果一个 n 位正整数等于其各位数字的 n 次方之和,则称该数为阿姆斯特朗数。

如果是 3 位数的阿姆斯特朗数,则每位数的立方的和等于该数本身。例如 153 是一个阿姆斯特朗数。因为: 153 = 1*1*1 + 5*5*5 + 3*3*3

该程序建立在如何检查整数是否为阿姆斯特朗数的概念之上。

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

public class Armstrong {
  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;

      // number of digits calculation
      while (originalNumber != 0) {
        originalNumber /= 10;
        ++digits;
      }

      originalNumber = number;

      // result contains sum of nth power of its digits
      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

在上面的程序中,检查给定数字 lowhigh 之间的每个数字。

每次检查后, digitsresult 恢复为 0。