Skip to content

Instantly share code, notes, and snippets.

@ryosan-470
Created January 9, 2014 08:27
Show Gist options
  • Save ryosan-470/8331089 to your computer and use it in GitHub Desktop.
Save ryosan-470/8331089 to your computer and use it in GitHub Desktop.
フィボナッチ数列を高速に求める
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
long[] fib = new long[5000];
System.out.println(fibonacci(n+1, fib));
}
public static long fibonacci(int x, long fib[]){
if(x == 0) return 0;
if(x == 1) return 1;
if(fib[x] != 0) return fib[x]; // キャッシュしていた結果を返す
fib[x] = fibonacci(x - 1, fib) + fibonacci(x - 2, fib); // 結果をキャッシュする
return fib[x];
}
}
@ryosan-470
Copy link
Author

フィボナッチ数列

フィボナッチ数列の第n項を高速化して求める

キャッシュを使うことで再帰的に求めるときに比べ計算量を落とすことができる
再帰    O(2^n)
キャッシュ O(n)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment