這篇文章給大家分享的是有關使用Python實現(xiàn)分數(shù)序列求和的案例的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
站在用戶的角度思考問題,與客戶深入溝通,找到東寶網站設計與東寶網站推廣的解決方案,憑借多年的經驗,讓設計與互聯(lián)網技術結合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:網站設計制作、成都網站設計、企業(yè)官網、英文網站、手機端網站、網站推廣、申請域名、網站空間、企業(yè)郵箱。業(yè)務覆蓋東寶地區(qū)。直接上代碼
#!/usr/bin/env python # coding:UTF-8 """ @version: python3.x @author:曹新健 @contact: 617349013@qq.com @software: PyCharm @file: 1223.py @time: 2018/12/23 20:56 """ ''' 有一分數(shù)序列:2/1,3/2,5/3,8/5,13/8,21/13...求出這個數(shù)列的前20項之和。 ''' """ #方法一 def g(n): if n <= 2: return n else: return g(n-1) + g(n-2) sum = 0 for i in range(1,21): sum += g(i+1)/g(i) print(sum) """ #方法二 numerator = 2 denominator = 1 sum = 0 while True: try: n = int(input("請輸入一個整數(shù):")) except ValueError: print("輸入錯誤,請輸入整數(shù)") else: for i in range(n): sum += numerator / denominator numerator, denominator = numerator + denominator, numerator print(sum) break
補充拓展:Python分數(shù)加法的實現(xiàn)
或多或少大家都會覺得用電腦計算器不能顯示分數(shù)很麻煩,所以用Python做一個分數(shù)加法是極好的
a = input() b = a.split(',') def eu(a,b): if a < b: a, b = b, a r = 1 while r != 0: r = a % b a = b b = r return a num1 = b[0].split('/') num2 = b[1].split('/') sum1 = int(num1[0])*int(num2[1]) + int(num2[0])*int(num1[1]) sum2 = int(num1[1])*int(num2[1]) GCD = eu(sum1,sum2) c = int(sum1/GCD) d = int(sum2/GCD) if c%d == 0: print(int(c/d)) else: print(str(c)+ '/'+str(d))
實際上用fractions模塊可以瞬間解決問題
from fractions import Fraction a,b = (input().split(',')) sum=Fraction(a)+Fraction(b) print(sum)
感謝各位的閱讀!關于“使用Python實現(xiàn)分數(shù)序列求和的案例”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!