summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSt33v <st33v@woodenspoon.net>2013-05-18 15:28:12 +1000
committerSt33v <st33v@woodenspoon.net>2013-05-18 15:28:12 +1000
commitb10b7b7550bec22ab463ea2ae95b1467dbd0e442 (patch)
treec655640dfc5b3a9830483f8760706e4fd5b26484
parent8913938c7339c59d13420ac95ab4351db296d97c (diff)
Create fibonacci
Two functions that calculate the first 'n' member of the Fibonacci series.
-rw-r--r--fibonacci22
1 files changed, 22 insertions, 0 deletions
diff --git a/fibonacci b/fibonacci
new file mode 100644
index 0000000..f817a9a
--- /dev/null
+++ b/fibonacci
@@ -0,0 +1,22 @@
+# fiBonacci.R
+# playing with recursion coz bored
+# Stephen Pratt 25/08/2009 4:19:50 PM
+
+#######################################################################
+# Recursive version of Fibonacci series (very inefficient)
+fiBonacci <- function(n, count = T, first = T){
+ if(first) i <<- 0
+ if(count) i <<- i + 1
+ if(as.integer(n) %in% 0:1) return(n)
+ fib <- fiBonacci(n = n-1, co=count, f=F) + fiBonacci(n = n-2, co=count, f=F)
+ ifelse(first, return(list(fib = fib, i = i)), fib)
+}
+#######################################################################
+# dreaded for-loop version of Fibonacci series
+fiB <- function(n){
+ fib <- NULL
+ fib[1] <- 0 # indexes offset by 1 because R can't handle x[0]
+ fib[2] <- 1
+ for(i in 3:(n+1)) fib[i] <- fib[i-1] + fib[i-2]
+ return(fib)
+}