Newbie Help

Please support our Python advertiser: Programming Forums - DaniWeb Sister Site
Thread Solved

Join Date: Oct 2006
Posts: 34
Reputation: babutche is an unknown quantity at this point 
Solved Threads: 0
babutche babutche is offline Offline
Light Poster

Newbie Help

 
0
  #1
Dec 29th, 2006
Hi,

I am trying to figure out how to print tracing information for Fibonacci numbers.

output =

Computing fib(4)

Leaving fib(4) returning 3


Can anyone steer me in the right direction?

This is what I have:

  1. import math
  2. def fib(n):
  3. if n < 3:
  4. return 1
  5. while n >= 3:
  6. x = n-1
  7. y = n-2
  8. print "Computing fib", n
  9. print "fib", x, "+", "fib", y
  10. print "Leaving fib", n
  11. print "Return", fib(x) + fib(y)
  12. return fib(n-1) + fib(n-2)

My output is looking like this:

  1. >>>
  2. >>> fib(4)
  3. Computing fib 4
  4. fib 3 + fib 2
  5. Leaving fib 4
  6. Return Computing fib 3
  7. fib 2 + fib 1
  8. Leaving fib 3
  9. Return 2
  10. 3
  11. Computing fib 3
  12. fib 2 + fib 1
  13. Leaving fib 3
  14. Return 2
  15. 3
  16. >>>


I cannot get my return of the Fibonacci number to work properly and when I ran this program with fib(10) it ran forever.


:mrgreen: Thanks!
Reply With Quote Quick reply to this message  
Join Date: Dec 2006
Posts: 1,065
Reputation: woooee is a jewel in the rough woooee is a jewel in the rough woooee is a jewel in the rough 
Solved Threads: 299
woooee woooee is offline Offline
Veteran Poster

Re: Newbie Help

 
0
  #2
Dec 29th, 2006
I cannot get my return of the Fibonacci number to work properly and when I ran this program with fib(10) it ran forever.
'Ran forever' because you are calculating using the same number over and over. Look at your output. If you want to compute a fib you first have to start with two numbers. The sequence 1, 1, 2, 3, 5 actually starts with zero and one. You can start with any two numbers you want, or with one number and number-1, so if we start with 10 and 10-1=9, store those two numbers in a list, pass the list to the function which adds them together, then element[0] = element[1], and element[1] = the sum, and continue by returning the updated list. If you still can't figure it out, post back. When testing a loop, it is a good idea to put in a counter and if it is greater than some number, say 1000, exit with an error message.

Edit: I'm now wondering if you want to calculate the fibs used to calculate a number. I would think that mpossible as it can be any two numbers in combination. For example 10=9+1 or 8+2, etc. If you can explain what you want to do in words or have some math, please post back.
Last edited by woooee; Dec 29th, 2006 at 7:15 pm.
Reply With Quote Quick reply to this message  
Join Date: Oct 2006
Posts: 34
Reputation: babutche is an unknown quantity at this point 
Solved Threads: 0
babutche babutche is offline Offline
Light Poster

Re: Newbie Help

 
0
  #3
Dec 29th, 2006
Hi,

See post below please. Sorry I forgot code tags.
Last edited by babutche; Dec 29th, 2006 at 9:01 pm. Reason: Code tags
Reply With Quote Quick reply to this message  
Join Date: Oct 2006
Posts: 34
Reputation: babutche is an unknown quantity at this point 
Solved Threads: 0
babutche babutche is offline Offline
Light Poster

Re: Newbie Help

 
0
  #4
Dec 29th, 2006
Hi,



It is suppose to show each time the recursion is called and returned in the recursive program. I really don't understand it myself because I am having a hard time understanding recursion. If anyone can explain how recursion works I would greatly appreciate it. I have read about it but it just looks like a loop to me. I am not very good at this. I am just a beginner. Sorry.

Anyway I have changed my program around but I still cannot get it to print tracing information. this is what I have:

  1. import math
  2. def fib(n):
  3. a,b = 0,1
  4. while b < n:
  5. print b,
  6. print "Computing fib: ", n
  7. a, b = b, a+b
  8. print a, b
  9. print "Leaving fib", n


I am stuck! I don't understand.
Reply With Quote Quick reply to this message  
Join Date: Dec 2006
Posts: 1,065
Reputation: woooee is a jewel in the rough woooee is a jewel in the rough woooee is a jewel in the rough 
Solved Threads: 299
woooee woooee is offline Offline
Veteran Poster

Re: Newbie Help

 
0
  #5
Dec 29th, 2006
Recursion usually means something that calls itself. The following is a link to a sort that uses recursion. Note that in the sort there is a way to tell if the item has already been tested/done. Recursion is used for things like sorts and walking a directory to get files from subdirectories.
http://www.faqts.com/knowledge_base/view.phtml/aid/4491
  1. ##Recursion to compute a factorial
  2. def factorial(n) :
  3. if n < 2 :
  4. return 1
  5. else :
  6. return ( n * factorial(n-1) )
Reply With Quote Quick reply to this message  
Join Date: Oct 2004
Posts: 4,135
Reputation: vegaseat is just really nice vegaseat is just really nice vegaseat is just really nice vegaseat is just really nice vegaseat is just really nice 
Solved Threads: 946
Moderator
vegaseat's Avatar
vegaseat vegaseat is offline Offline
DaniWeb's Hypocrite

Re: Newbie Help

 
0
  #6
Dec 30th, 2006
A function calling itself, or recursion, is like a loop. As with any loop you have to give it an exit condition, or it will keep going. So, watch out that your test print statements don't ruin your exit condition or call the function itself.

Just out of curiosity I put in the only test print statement I could think of into the standard recursive Fibonacci Number function. Since the function calls itself twice each time around, it makes for a surprising number of time expensive function calls, and is as inefficient as the government!
[php]def fib(n):
print "Doing fib(%d)" % n # test!!!
if n < 2:
return n
else:
return fib(n - 1) + fib(n - 2)

print fib(10)
[/php]For fib(30) the recursive function is 75,000 times slower than the usual nonrecursive function ...
[php]def fib(n):
(current, previous) = (0, 1)
while n > 0:
(current, previous) = (previous, current + previous)
n -= 1
return current
[/php]
Last edited by vegaseat; Dec 30th, 2006 at 4:47 am.
May 'the Google' be with you!
Reply With Quote Quick reply to this message  
Join Date: Oct 2006
Posts: 34
Reputation: babutche is an unknown quantity at this point 
Solved Threads: 0
babutche babutche is offline Offline
Light Poster

Re: Newbie Help

 
0
  #7
Dec 30th, 2006
I can get this to print out the fib #. But I don't know how to print out each call/return. Maybe you can guide me in the right direction. Even though this problem has caused me some grief it, has been fun to mess with. But I want to get it to run properly.

Here is what I am figuring:

Let's take fib(7)

fib(7) = 13 = 8 + 5 (curr/ prev)

fib(6) = 8 = 5 + 3 (curr/ prev)

fib(5) = 5 = 3 + 2 (curr/ prev )


2 + 3 = 5 is now curr + prev = curr(fib(6) curr)

2 = 2 is now fib(4)curr = fib(5)prev



fib(4) = 3 = 2 + 1 (curr/ prev)

fib(3) = 2 = 1 + 1 (curr/ prev)


I am realizing I need to store some things here but I'm not sure what or how, right now.
1 1 2 3 5 8 13


To call fib(7):
fib(7)
fib(6) fib(5)
fib(7-1) fib(7-2)
fib(5) fib(4) fib(4) fib(3)
fib(6-1) fib(6-2) fib(5-1) fib((5-2)

and so on.........
n = 7
but each time around n must decrease by 1. Right?
Then n is equal to the next fib.
So I need an accumulator?

The outside functions on the far left hand side = n-1 each time around the loop
The inside function on the far L.H. side = n-2 each time around loop
Right hand side is :
inside function = n-1
outside function = n-2

Well, I just got lost maybe you can help! Thanks!!!
Last edited by babutche; Dec 30th, 2006 at 7:51 am. Reason: Align problem
Reply With Quote Quick reply to this message  
Join Date: Dec 2006
Posts: 1,065
Reputation: woooee is a jewel in the rough woooee is a jewel in the rough woooee is a jewel in the rough 
Solved Threads: 299
woooee woooee is offline Offline
Veteran Poster

Re: Newbie Help

 
0
  #8
Dec 31st, 2006
Originally Posted by babutche View Post
Let's take fib(7)

fib(7) = 13 = 8 + 5 (curr/ prev)

fib(6) = 8 = 5 + 3 (curr/ prev)

fib(5) = 5 = 3 + 2 (curr/ prev )
I am realizing I need to store some things here but I'm not sure what or how, right now.
1 1 2 3 5 8 13
Perhaps append a fib sequence to a list until the value is greater than the input number? That should give you the info. If you want to use recursion, you can use it to calculate the fib list. Personally, I would use a while loop, but whatever.
Last edited by woooee; Dec 31st, 2006 at 2:57 pm.
Reply With Quote Quick reply to this message  
Join Date: Dec 2006
Posts: 1,065
Reputation: woooee is a jewel in the rough woooee is a jewel in the rough woooee is a jewel in the rough 
Solved Threads: 299
woooee woooee is offline Offline
Veteran Poster

Re: Newbie Help

 
0
  #9
Dec 31st, 2006
Originally Posted by babutche View Post
The outside functions on the far left hand side = n-1 each time around the loop
The inside function on the far L.H. side = n-2 each time around loop
If n=list element >= input number, then n-1 and n-2 = element numbers that make up the fib, or am I also confused?
Reply With Quote Quick reply to this message  
Reply

This thread has been marked solved.
Perhaps start a new thread instead?
Message:




Views: 1614 | Replies: 8
Thread Tools Search this Thread



Tag cloud for Python
About Us | Contact Us | Advertise | DaniWeb | Acceptable Use Policy | RSS Feed

©2003 - 2009 DaniWeb® LLC