如果我正確理解你的問題......這是一個遞歸實現:
def gaus(n, ls = list()):
if n == 1:
return ls
else:
ls.append(n/2.) # Step 1: n/2
ls.append(ls[-1] * 3 + 1) # Step 2: (n/2) * 3 + 1
return gaus(n - 1, ls)
print gaus(30)
結果是這樣的名單:
[15.0, 46.0, 14.5, 44.5, 14.0, 43.0, 13.5, 41.5, 13.0, 40.0, 12.5, 38.5, 12.0, 37.0, 11.5, 35.5, 11.0, 34.0, 10.5, 32.5, 10.0, 31.0, 9.5, 29.5, 9.0, 28.0, 8.5, 26.5, 8.0, 25.0, 7.5, 23.5, 7.0, 22.0, 6.5, 20.5, 6.0, 19.0, 5.5, 17.5, 5.0, 16.0, 4.5, 14.5, 4.0, 13.0, 3.5, 11.5, 3.0, 10.0, 2.5, 8.5, 2.0, 7.0, 1.5, 5.5, 1.0, 4.0]
編輯:
def print_gaus(n):
if n == 1:
return
else:
if n % 2 == 0:
print (n/2),
print (n/2 * 3 + 1),
print_gaus(n/2 * 3 + 1)
print_gaus(n - 1)
print print_gaus(30)
但注意,這將打破,因爲你的環境的最大遞歸深度。
提出新的問題,而不是 – GingerPlusPlus