java - 这个程序有什么问题。如果一个数字是完美的,例如 num 是 6,它应该打印 1*2*3。使用 BigInteger

标签 java biginteger perfect-numbers

package perfect;

import java.math.BigInteger;
import java.util.Scanner;

public class Perfect {

 public static void main(String[] args) 
   {

 Scanner input = new Scanner(System.in);
 System.out.println("Enter the number");

 BigInteger n = input.nextBigInteger();
 BigInteger sum  = BigInteger.valueOf(0);
 BigInteger i = BigInteger.valueOf(1);
 BigInteger mul = BigInteger.valueOf(1);

 for(; i.compareTo(n)< 0; i.add(BigInteger.ONE))
      {

       if(n.mod(i).equals(BigInteger.ZERO))
         {

             sum = sum.add(i);
             mul = mul.multiply(i) ;
         }
     }
     if(sum == n)
     {

       System.out.println(n+ "=" +mul) ;
     }
     else
     {
         System.out.println("the given number " +n+ " is not a perfect 
      number");
      }
        }

        }

因为它必须打印 6 = 1*2*3 我使用了 BigInteger。但它没有显示任何错误,但程序在控制台中从用户那里获取号码后我没有得到任何输出。

最佳答案

三个问题:

  • BigInteger 是不可变的,因此您应该改为 i = i.add(BigInteger.ONE)
  • sumn 进行比较时,您应该执行 sum.equals(n)
  • 将因子存储到列表中,而不是将它们累积乘回到输入
  • 如果你格式化代码,它看起来会更好
import java.math.BigInteger;
import java.util.Scanner;
import java.util.ArrayList;

public class Perfect {

  public static void main(String[] args) {

    Scanner input = new Scanner(System.in);
    System.out.println("Enter the number");

    BigInteger n = input.nextBigInteger();
    BigInteger sum = BigInteger.valueOf(0);
    BigInteger i = BigInteger.valueOf(1);
    ArrayList<BigInteger> factors = new ArrayList<BigInteger>();

    for (; i.compareTo(n) < 0; i = i.add(BigInteger.ONE)) {

      if (n.mod(i).equals(BigInteger.ZERO)) {

        sum = sum.add(i);
        factors.add(i);
      }
    }
    if (sum.equals(n)) {

      System.out.print(n + "=" + factors.get(0));
      for (int idx = 1; idx < factors.size(); idx++) {
        System.out.print("*" + factors.get(idx));
      }
      System.out.println();
    } else {
      System.out.println("the given number " + n + " is not a perfect number");
    }
  }

}

关于java - 这个程序有什么问题。如果一个数字是完美的,例如 num 是 6,它应该打印 1*2*3。使用 BigInteger,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55153651/

相关文章:

Python - 完美数搜索的优化

java - 输入的完美数

java - HBase 1.2.1 standalone in Docker 无法连接

java - 如果 BigInteger 对于 int 来说太大,如何返回 int?

Java将无符号大整数转换为无符号字节

Python:大整数键的快速字典

java - 如何在从 Web 服务器接收图标 URL 时将图标添加到自定义 ListView 中

java - Google App Engine - JCache 或 Memcache API?

java - 如何在Android Studio中添加不包含特定程序包的lib项目?

c++ - 完全数程序中的逻辑错误