| New Reply |
A bit of trouble with Python |
Share Thread | Thread Tools |
| Jun14-12, 09:11 PM | #1 |
|
|
A bit of trouble with Python
I tried the following code:
Code:
def factorial(n):
if (n == 0):
return 1
else:
return n*factorial(n-1)
def ncr(n,r):
return ((factorial(n))/(factorial(r)*factorial(n-r)))
number = 0
for n in range(100):
for r in range(100):
print ncr(n,r)
Unfortunately, running from the command line, I get: Code:
Traceback (most recent call last):
File "Pythontest.py", line 14, in <module>
print ncr(n,r)
File "Pythontest.py", line 8, in ncr
return ((factorial(n))/(factorial(r)*factorial(n-r)))
File "Pythontest.py", line 5, in factorial
return n*factorial(n-1)
File "Pythontest.py", line 5, in factorial
return n*factorial(n-1)
File "Pythontest.py", line 5, in factorial
return n*factorial(n-1)
|
| Jun14-12, 09:30 PM | #2 |
|
|
you have to have [itex]0 \le r \le n[/itex]. your definition of factorial goes into an infinite callback if [itex]n < 0[/itex].
|
| Jun15-12, 06:31 AM | #3 |
|
|
Also, for general purposes...factorial is not defined for negative numbers, so, you should enhance your 'def factorial' and guard (validate) against negative numbers and possibly raise an exception, etc...you know, for when you use this def in a more complex program.
|
| Jun16-12, 10:29 AM | #4 |
|
|
A bit of trouble with Python |
| Jul22-12, 01:32 AM | #5 |
|
|
May I ask why you are doing it recursively? It's not particularly efficient in Python when done that way.
Code:
def rfac (x):
return x * rfac (x-1) if x > 0 else 1
def ifac (x):
f = 1
for i in range (1, x+1):
f *= i
return f
from timeit import Timer
print (Timer ("rfac(20)", "from __main__ import rfac")).timeit()
print (Timer ("ifac(20)", "from __main__ import ifac")).timeit()
10.4178638458 5.76771497726 There are much faster ways to compute it, if you search the web. Edit: I am not sure I would check or throw for negative input. There's defensive programming, and there's paranoia. It should not happen in practice. I admit this is personal style. I understand there cases where it might (web app), but seriously ... use a precomputed lookup table of N! if it's a web app. |
| New Reply |
| Thread Tools | |
Similar Threads for: A bit of trouble with Python
|
||||
| Thread | Forum | Replies | ||
| Compile Python, Matlab and Python | Programming & Comp Sci | 3 | ||
| Trouble with Python sum function | Engineering, Comp Sci, & Technology Homework | 3 | ||
| help in Python rk4 | Programming & Comp Sci | 1 | ||
| Python to C++ | Programming & Comp Sci | 9 | ||
| GTK and Python | Programming & Comp Sci | 2 | ||