Python求平方根至少有三種方式
創(chuàng)新互聯(lián)公司堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的興山網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
1.最簡(jiǎn)單的方式是求0.5次方
4?**?0.5
2.使用math包的sqrt函數(shù)
math.sqrt(4)
3.使用numpy包的sqrt函數(shù)
numpy.sqrt(4)
可以使用math庫(kù)
import matha = 4print math.sqrt(4) # 2
也可以直接利用python的**運(yùn)算符
a = 8a**(1/3) # 開(kāi)3次方相當(dāng)于1/3次乘方 結(jié)果是2 math中其他常用的數(shù)學(xué)函數(shù):ceil(x) 取頂floor(x) 取底fabs(x) 取絕對(duì)值factorial (x) 階乘hypot(x,y) sqrt(x*x+y*y)pow(x,y) x的y次方sqrt(x) 開(kāi)平方log(x)log10(x)trunc(x) 截?cái)嗳≌麛?shù)部分isnan (x) 判斷是否NaN(not a number)degree (x) 弧度轉(zhuǎn)角度radians(x) 角度轉(zhuǎn)弧度
首先,導(dǎo)入math函數(shù)庫(kù)。
一、計(jì)算平方根
輸入一個(gè)數(shù)值,保存在變量n中。
相關(guān)推薦:《Python基礎(chǔ)教程》
用函數(shù)sqrt,計(jì)算變量平方根的值。
二、計(jì)算冪
可以用函數(shù)exp,計(jì)算e的x次冪。
三、計(jì)算對(duì)數(shù)
設(shè)置兩個(gè)數(shù),保存在變量n和a中。
接著,用log函數(shù)計(jì)算以a為基數(shù)n的對(duì)數(shù)。
運(yùn)行程序,其結(jié)果如下圖所示。
python中可以使用2**0。5表示根號(hào)二。
python中表示根號(hào)二的方法有許多,比如使用math模塊、使用內(nèi)置函數(shù)pow或使用數(shù)學(xué)表達(dá)式。使用雙星號(hào)表達(dá)根號(hào)二屬于數(shù)學(xué)表達(dá)式。這種方式需要用戶輸入一個(gè)數(shù)字,并使用指數(shù)運(yùn)算符**來(lái)計(jì)算該數(shù)的平方根。而輸入的代碼一般以num**0。5來(lái)表示根號(hào)數(shù)。
Python中星號(hào)可以對(duì)修飾的變量進(jìn)行拆分,對(duì)修飾的形式參數(shù)進(jìn)行參數(shù)聚集。單星號(hào)將被修飾的變量按元素方式拆分,對(duì)修飾的形式參數(shù)進(jìn)行參數(shù)聚集。雙星號(hào)將被修飾的變量按鍵值對(duì)進(jìn)行拆分,對(duì)修飾的形式參數(shù)進(jìn)行參數(shù)聚集。
1:二分法
求根號(hào)5
a:折半:?????? 5/2=2.5
b:平方校驗(yàn):? 2.5*2.5=6.255,并且得到當(dāng)前上限2.5
c:再次向下折半:2.5/2=1.25
d:平方校驗(yàn):1.25*1.25=1.56255,得到當(dāng)前下限1.25
e:再次折半:2.5-(2.5-1.25)/2=1.875
f:平方校驗(yàn):1.875*1.875=3.5156255,得到當(dāng)前下限1.875
每次得到當(dāng)前值和5進(jìn)行比較,并且記下下下限和上限,依次迭代,逐漸逼近平方根:
代碼如下:
import math
from math import sqrt
def sqrt_binary(num):
x=sqrt(num)
y=num/2.0
low=0.0
up=num*1.0
count=1
while abs(y-x)0.00000001:
print count,y
count+=1
if (y*ynum):
up=y
y=low+(y-low)/2
else:
low=y
y=up-(up-y)/2
return y
print(sqrt_binary(5))
print(sqrt(5))
2:牛頓迭代
仔細(xì)思考一下就能發(fā)現(xiàn),我們需要解決的問(wèn)題可以簡(jiǎn)單化理解。
從函數(shù)意義上理解:我們是要求函數(shù)f(x) = x2,使f(x) = num的近似解,即x2 - num = 0的近似解。
從幾何意義上理解:我們是要求拋物線g(x) = x2 - num與x軸交點(diǎn)(g(x) = 0)最接近的點(diǎn)。
我們假設(shè)g(x0)=0,即x0是正解,那么我們要做的就是讓近似解x不斷逼近x0,這是函數(shù)導(dǎo)數(shù)的定義:
從幾何圖形上看,因?yàn)閷?dǎo)數(shù)是切線,通過(guò)不斷迭代,導(dǎo)數(shù)與x軸的交點(diǎn)會(huì)不斷逼近x0。
1、創(chuàng)建python文件,testmath.py;
2、編寫python代碼,計(jì)算根號(hào)2;
import?math
print(math.sqrt(2))
3、右擊,選擇‘在終端中運(yùn)行Python文件’;
4、查看執(zhí)行結(jié)果為1.4142135623730951;