1. 程式人生 > 程式設計 >在python中實現求輸出1-3+5-7+9-......101的和

在python中實現求輸出1-3+5-7+9-......101的和

第一種:

i=0
sum=0
a=0
while i<102:
 if i>=1 and i%4==1:
  sum+=i
 elif i%2!=0 and i!=1:
  a=a+i
 i+=1
print(sum-a)

第二種:

a=1
b=-3
sum1=0
sum2=0
while a<=101and b>=-99:
 sum1+=a
 sum2+=b
 a+=+4
 b+=-4
print(sum1+sum2+101)

第三種:

print(sum(range(1,102,4))-sum(range(3,4)))

自我反省:

第一種與第二種是我寫的 第三種是我朋友寫的 當你學習Python取得一點點成績的時候不要驕傲

補充知識:Python語言求1+3!+5!+7!+9!+50!的幾種思路

有一道Python面試題,求和1+3!+5!+7!+9!+50!

方法一: 常規思路

L = [1,3,5,7,9,50]
 
 
def func(n):
 if n == 1:
  return 1
 else:
  return n * func(n-1)
 
total = 0
 
for i in L:
 total = total + func(i)
print(total)

方法二: 遞迴求和

>>> def func(n):
...  return 1 if n == 1 else n * func(n-1)
>>> sum([func(i) for i in [1,50]])
30414093201713378043612608166064768844377641568960512000000368047L

方法三: 函式程式設計

>>> from functools import reduce
>>> sum([reduce(lambda x,y:x*y,range(1,i+1)) for i in list(range(1,10,2)) + [50]])
30414093201713378043612608166064768844377641568960512000000368047L

方法四: 藉助模組

>>> from scipy.special import factorial
>>> sum(factorial([1,50],exact=True))
30414093201713378043612608166064768844377641568960512000000368047L

以上這篇在python中實現求輸出1-3+5-7+9-......101的和就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。