2016-09-24 39 views
-1

我設法讓我的代碼工作,所以它產生PI:生成PI超過2315位

while True: 
     print("how many digits of pi would you like?") 


     def make_pi(): 
      q, r, t, k, m, x = 1, 0, 1, 1, 3, 3 
      for j in range(1000000): 
       if 4 * q + r - t < m * t: 
        yield m 
        q, r, t, k, m, x = 10 * q, 10 * (r - m * t), t, k, (10 * (3 * q + r)) // t - 10 * m, x 
       else: 
        q, r, t, k, m, x = q * k, (2 * q + r) * x, t * x, k + 1, (q * (7 * k + 2) + r * x) // (t * x), x + 2 


     digits = make_pi() 
     pi_list = [] 
     my_array = [] 

     for i in make_pi(): 
      my_array.append(str(i)) 

     number = int(input())+2 
     my_array = my_array[:1] + ['.'] + my_array[1:] 
     big_string = "".join(my_array[: number ]) 
     print("here is the string:\n %s" % big_string) 

但是不管我多麼增加range的代碼只有一個最大的圓周率2315位輸出小數點後

how can I fix this? 
+3

你要確保增加'number'大於2315? – TigerhawkT3

+0

我試圖生成超過10000個數字,並增加了範圍,但無濟於事 –

+0

這很好,但是您是否增加了'number',它實際控制了打印多少位數? – TigerhawkT3

回答

0

怎樣使參數化make_pi生成器接受數位數?

事情是這樣的:

def make_pi(num_digits): 
    q, r, t, k, m, x = 1, 0, 1, 1, 3, 3 
    for j in range(num_digits): 
     if 4 * q + r - t < m * t: 
      yield m 
      q, r, t, k, m, x = 10 * q, 10 * \ 
       (r - m * t), t, k, (10 * (3 * q + r)) // t - 10 * m, x 
     else: 
      q, r, t, k, m, x = q * \ 
       k, (2 * q + r) * x, t * x, k + \ 
       1, (q * (7 * k + 2) + r * x) // (t * x), x + 2 


num_digits = 10000 
pi = "".join([str(d) for d in make_pi(num_digits)]) 
print("{0}.{1}".format(pi[:1], pi[1:])) 
+0

請求10000時,您實際獲得了多少位數? –

+0

好的我有懷疑,我認爲這證實了pycharm有某種錯誤,因爲我嘗試了^代碼,發生了同樣的事情 –