我应该写一个代码来检查给定的数字是否属于斐波那契数列。经过几个小时的努力,这是我想到的:

public class TP2 {

    /**
     * @param args
     */

    public static boolean ehFibonacci(int n) {
        int fib1 = 0;
        int fib2 = 1;
        do {
            int saveFib1 = fib1;
            fib1 = fib2;
            fib2 = saveFib1 + fib2;
            }
        while (fib2 <= n);

        if (fib2 == n)
            return true;
        else
            return false;

    }
    public static void main(String[] args) {
        int n = 8;
        System.out.println(ehFibonacci(n));

    }
}

我一定做错了,因为它总是返回“false”。有关如何解决此问题的任何提示?

最佳答案

您在fib2 <= n时继续循环,因此,当您不在循环中时,fib2始终为> n,因此它返回false

关于java - Java:检查数字是否属于斐波那契数列,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/13336593/

10-09 00:31