これら 2 つの関数を 1 つの再帰関数に結合して、この結果を得るにはどうすればよいですか。
factorial(6)
1! = 1
2! = 2
3! = 6
4! = 24
5! = 120
6! = 720
これは私の階乗関数の現在のコードです:
def factorial(n):
if n < 1: # base case
return 1
else:
return n * factorial(n - 1) # recursive call
def fact(n):
for i in range(1, n+1 ):
print "%2d! = %d" % (i, factorial(i))
このコードが生成する出力は次のとおりです。
fact(6)
1! = 1
2! = 2
3! = 6
4! = 24
5! = 120
6! = 720
ご覧のとおり、これら 2 つの関数を実行すると正しい答えが得られますが、2 つの関数を単純化して 1 つの再帰関数にしたかっただけです。