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