2015-12-02 09:20:27 -08:00
|
|
|
// functional/RecursiveFibonacci.java
|
2020-10-07 13:35:40 -06:00
|
|
|
// (c)2020 MindView LLC: see Copyright.txt
|
2015-12-02 09:20:27 -08:00
|
|
|
// We make no guarantees that this code is fit for any purpose.
|
2016-09-23 13:23:35 -06:00
|
|
|
// Visit http://OnJava8.com for more book information.
|
2015-12-02 09:20:27 -08:00
|
|
|
|
|
|
|
public class RecursiveFibonacci {
|
|
|
|
IntCall fib;
|
|
|
|
RecursiveFibonacci() {
|
|
|
|
fib = n -> n == 0 ? 0 :
|
|
|
|
n == 1 ? 1 :
|
|
|
|
fib.call(n - 1) + fib.call(n - 2);
|
|
|
|
}
|
|
|
|
int fibonacci(int n) { return fib.call(n); }
|
|
|
|
public static void main(String[] args) {
|
|
|
|
RecursiveFibonacci rf = new RecursiveFibonacci();
|
|
|
|
for(int i = 0; i <= 10; i++)
|
|
|
|
System.out.println(rf.fibonacci(i));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* Output:
|
|
|
|
0
|
|
|
|
1
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
5
|
|
|
|
8
|
|
|
|
13
|
|
|
|
21
|
|
|
|
34
|
|
|
|
55
|
|
|
|
*/
|