summaryrefslogtreecommitdiff
path: root/graphs/cpp/lookup_table/fibo.cc
diff options
context:
space:
mode:
authorMartial Simon <msimon_fr@hotmail.com>2025-09-15 01:08:27 +0200
committerMartial Simon <msimon_fr@hotmail.com>2025-09-15 01:08:27 +0200
commitc9b6b9a5ca082fe7c1b6f58d7713f785a9eb6a5c (patch)
tree3e4f42f93c7ae89a364e4d51fff6e5cec4e55fa9 /graphs/cpp/lookup_table/fibo.cc
add: graphs et rushs
Diffstat (limited to 'graphs/cpp/lookup_table/fibo.cc')
-rw-r--r--graphs/cpp/lookup_table/fibo.cc15
1 files changed, 15 insertions, 0 deletions
diff --git a/graphs/cpp/lookup_table/fibo.cc b/graphs/cpp/lookup_table/fibo.cc
new file mode 100644
index 0000000..80b72b1
--- /dev/null
+++ b/graphs/cpp/lookup_table/fibo.cc
@@ -0,0 +1,15 @@
+#include "fibo.hh"
+
+long Fibo::operator()(int x)
+{
+ if (x <= 1)
+ return x;
+
+ std::optional<long> opt_lookup_table = lookup_table_.get(x);
+ if (opt_lookup_table)
+ return *opt_lookup_table;
+
+ auto res = (*this)(x - 1) + (*this)(x - 2);
+ lookup_table_.set(x, res);
+ return res;
+}