-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathL22Q12_Bunnies_Fibonacci.py
64 lines (57 loc) · 1.4 KB
/
L22Q12_Bunnies_Fibonacci.py
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
58
59
60
61
62
63
64
# Define a procedure, fibonacci, that takes a natural number as its input, and
# returns the value of that fibonacci number.
# Two Base Cases:
# fibonacci(0) => 0
# fibonacci(1) => 1
# Recursive Case:
# n > 1 : fibonacci(n) => fibonacci(n-1) + fibonacci(n-2)
#my initial solution without using recursion
def fibonacci(n):
counter=[0,1]
for i in range(n-1):
counter.append(counter[-1]+counter[-2])
return counter#[n]
#recursive solution
def fibonacci_recursive(n):
if n == 0:
return 0
if n == 1:
return 1
return fibonacci(n-1) + fibonacci(n-2)
#udacity solution
def fibonacciUdacity(n):
current = 0
after = 1
for i in range(n):
current, after = after, after + current
return current
#quiz: how many times is fibonacci(30) counted recursively in evaluating fibonacci_recursive(36)?
#print fibonacci(36-30+1) #working backwards on counter list starting from counter[1]
#>>> 13
#print fibonacci(0)
#>>> 0
#print fibonacci(1)
#>>> 1
#print fibonacci(2)
#>>> 1
#print fibonacci_recursive(3)
#>>> 2
#print fibonacci_recursive(4)
#>>> 3
#print fibonacci_recursive(5)
#>>> 5
#print fibonacci_recursive(6)
#>>> 8
#print fibonacci(7)
#>>> 13
#print fibonacci_recursive(7)
#>>> 13
#print fibonacciUdacity(7)
#>>> 13
#print fibonacci(15)
#>>> 610
#print fibonacci_recursive(15)
#>>> 610
#print fibonacciUdacity(15)
#>>> 610
#print fibonacci_recursive(36)