diff options
author | Braxton Hall | 2022-10-24 23:55:09 +0000 |
---|---|---|
committer | GitHub | 2022-10-24 23:55:09 +0000 |
commit | 5b3e4fb8a606385392b24dba3553db3dcb1cd711 (patch) | |
tree | 666aa4198d53409554eef85f1d8839442c196e1f /entries/dewert99/fib.rs | |
parent | 7ed13a92711a35a9c263c1f53e33e308653ae727 (diff) | |
parent | 40fdd4d0694f2dc0dd394901dad9884d277459db (diff) |
Merge pull request #30 from dewert99/main
dewert99 Fibonacci
Diffstat (limited to 'entries/dewert99/fib.rs')
-rw-r--r-- | entries/dewert99/fib.rs | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/entries/dewert99/fib.rs b/entries/dewert99/fib.rs new file mode 100644 index 0000000..ecf0a85 --- /dev/null +++ b/entries/dewert99/fib.rs @@ -0,0 +1,22 @@ +const MAX: usize = 94; + +const fn fibc<const N: usize>() -> [u64; N] { + let mut res = [0; N]; + res[1] = 1; + let mut i = 2; + while i < N { + res[i] = res[i - 1] + res[i - 2]; + i += 1; + } + res +} + +static FIB: [u64; MAX] = fibc(); + +pub fn fib(n: usize) -> Option<u64> { + if n >= MAX { + None // Fib of n wouldn't fit in 64-bits + } else { + Some(FIB[n]) + } +} |