-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathFibonacci.java
More file actions
57 lines (48 loc) · 1.89 KB
/
Fibonacci.java
File metadata and controls
57 lines (48 loc) · 1.89 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
package DynamicProgramming;
public class Fibonacci {
public static void main(String[] args) throws InterruptedException {
final int fib = 50;
Thread t1 = Thread.ofPlatform().start(() -> {
var start = System.currentTimeMillis();
System.out.printf("\nBF - fib(%d) = %d\n", fib, calculateFibonacci(fib));
var end = System.currentTimeMillis();
System.out.printf("It took %dms to compute.\n", end - start);
});
Thread t2 = Thread.ofPlatform().start(() -> {
var start = System.currentTimeMillis();
System.out.printf("\nDP - fib(%d) = %d\n", fib, calculateFibonacciBottomsUp(fib));
var end = System.currentTimeMillis();
System.out.printf("It took %dms to compute.\n", end - start);
});
Thread t3 = Thread.ofPlatform().start(() -> {
var start = System.currentTimeMillis();
System.out.printf("\nOP - fib(%d) = %d\n", fib, calculateFibonacci_Optimized(fib));
var end = System.currentTimeMillis();
System.out.printf("It took %dms to compute.\n", end - start);
});
t1.join();
t2.join();
t3.join();
}
private static long calculateFibonacci(final int num) {
if (num < 2) return num;
return calculateFibonacci(num - 1) + calculateFibonacci(num - 2);
}
private static long calculateFibonacciBottomsUp(final int num) {
var memo = new long[num];
memo[0] = 1;
memo[1] = 1;
for (int i = 2; i < num; i++) {
memo[i] = memo[i - 1] + memo[i - 2];
}
return memo[num - 1];
}
private static long calculateFibonacci_Optimized(final int num) {
long first = 1, second = 1;
for(int i = 2; i < num; i++) {
second = first + second;
first = second - first;
}
return second;
}
}