python求函數根 Python求根

利用Python語言計算方程的根

import math

讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:國際域名空間、虛擬空間、營銷軟件、網站建設、工農網站維護、網站推廣。

def erfenfa(function, a, b): #定義函數,利用二分法求方程的根,function為具體方程,a,b為根的取值范圍

start = a

end = b

if function(a) == 0:?

return a

elif function(b) == 0:

return b

elif function(a) * function(b) 0:?

print("couldn't find root in [a,b]")

return

else:

mid = (start + end) / 2

while abs(start - mid) 0.0000001:?

if function(mid) == 0:

return mid

elif function(mid) * function(start) 0:

end = mid

else:

start = mid

mid = (start + end) / 2

return mid

def f(x):#定義構造方程式函數

return math.pow(x, 5) -15*math.pow(x, 4) +85*math.pow(x, 3)-225*pow(x,2)+274*x - 121

print(round(erfenfa(f, 1.5, 2.4),6))

python如何求平方根

1:二分法

求根號5

a:折半:?????? 5/2=2.5

b:平方校驗:? 2.5*2.5=6.255,并且得到當前上限2.5

c:再次向下折半:2.5/2=1.25

d:平方校驗:1.25*1.25=1.56255,得到當前下限1.25

e:再次折半:2.5-(2.5-1.25)/2=1.875

f:平方校驗:1.875*1.875=3.5156255,得到當前下限1.875

每次得到當前值和5進行比較,并且記下下下限和上限,依次迭代,逐漸逼近平方根:

代碼如下:

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:牛頓迭代

仔細思考一下就能發現,我們需要解決的問題可以簡單化理解。

從函數意義上理解:我們是要求函數f(x) = x2,使f(x) = num的近似解,即x2 - num = 0的近似解。

從幾何意義上理解:我們是要求拋物線g(x) = x2 - num與x軸交點(g(x) = 0)最接近的點。

我們假設g(x0)=0,即x0是正解,那么我們要做的就是讓近似解x不斷逼近x0,這是函數導數的定義:

從幾何圖形上看,因為導數是切線,通過不斷迭代,導數與x軸的交點會不斷逼近x0。

python牛頓法求多項式的根

#includeiostream.h

#includemath.h

#includeconio.h

const int N=200;

//帶入原函數后所得的值

double f(float x)

{

return (x*x*x-1.8*x*x+0.15*x+0.65);

}

//帶入一階導函數后所得的值

double f1(double x)

{

return (3*x*x-3.6*x+0.15);

}

//牛頓迭代函數

double F(double x)

{

double x1;

x1=x-1.0*f(x)/f1(x);

return (x1);

}

void main()

{

double x0,D_value,x1,y[4];

int k=0,count=0;

for(;;)

{

if(count==3)break;

cout"輸入初始值:";

cinx0;

do

{

k++;

x1=F(x0);

D_value=fabs(x1-x0);

x0=x1;

}

while((D_value0.000005)(k=N));

for(int j=0,flag=0;jcount;j++)

{

if(fabs(y[j]-x1)0.000005)

{ flag=1;

cout"該數值附近的根已經求出,請重新換近似值"endl;

break;

}

}

if(flag==1)

continue;

else

{

cout"方程的一個根:"x1","" 迭代次數為:"kendl;

y[count]=x1;

count++;

}

//else

//cout"計算失敗!"endl;

}

}

//你的程序其實沒問題,牛頓迭代法本身循環一次只能找到一個答案,只要再建一個循環控制使

//用迭代法的次數和判斷根的個數就行。我又加了一個判斷是否有重復的根的循環。

//希望能對你有所幫助。

python怎么求解一元二次方程的根?

import numpy as np

def solve_quad(a,b,c):

if a == 0:

print('您輸入的不是二次方程!')

else:

delta = b*b-4*a*c

x = -b/(2*a)

if delta == 0:

print('方程有惟一解,X=%f'%(x))

return x

elif delta 0:

x1 = x-np.sqrt(delta)/(2*a)

x2 = x+np.sqrt(delta)/(2*a)

print('方程有兩個實根:X1=%f,X2=%f'%(x1,x2))

return x1,x2

else:

x1 = (-b+complex(0,1)*np.sqrt((-1)*delta))/(2*a)

x2 = (-b-complex(0,1)*np.sqrt((-1)*delta))/(2*a)

print(x1,x2)

return x1,x2

Python

是完全面向對象的語言。函數、模塊、數字、字符串都是對象。并且完全支持繼承、重載、派生、多繼承,有益于增強源代碼的復用性。Python支持重載運算符和動態類型。相對于Lisp這種傳統的函數式編程語言,Python對函數式設計只提供了有限的支持。有兩個標準庫(functools, itertools)提供了Haskell和Standard ML中久經考驗的函數式程序設計工具。

本文名稱:python求函數根 Python求根
文章出自:http://m.kartarina.com/article48/dodedep.html

成都網站建設公司_創新互聯,為您提供微信公眾號微信小程序網頁設計公司做網站靜態網站關鍵詞優化

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

小程序開發
主站蜘蛛池模板: 亚洲gv猛男gv无码男同短文 | 亚洲国产精品成人精品无码区在线 | 中文字幕乱码无码人妻系列蜜桃| 潮喷大喷水系列无码久久精品| 野花在线无码视频在线播放| 人妻在线无码一区二区三区| 中文字幕乱偷无码AV先锋| 人妻少妇精品无码专区| 亚洲AV无码日韩AV无码导航 | 久久精品无码一区二区三区日韩 | 人妻aⅴ无码一区二区三区| 免费人成无码大片在线观看| 午夜人性色福利无码视频在线观看| 亚州AV综合色区无码一区| 亚洲AV中文无码字幕色三| 精品无码国产AV一区二区三区| 性无码免费一区二区三区在线| 免费无码又爽又刺激高潮软件| 午夜无码性爽快影院6080| 色窝窝无码一区二区三区成人网站 | 亚洲人成无码久久电影网站| 亚洲天堂2017无码中文| 亚洲av无码片在线播放| 国产色无码专区在线观看| 无码欧精品亚洲日韩一区夜夜嗨 | 人妻少妇无码精品视频区| 国产精品无码无片在线观看3D| 中文字幕AV无码一区二区三区| 免费A级毛片无码A∨免费| 四虎成人精品无码| 中文无码字慕在线观看| 影音先锋中文无码一区| 亚洲av日韩aⅴ无码色老头| 亚洲精品偷拍无码不卡av| 久久久久久亚洲Av无码精品专口| 久久久无码精品亚洲日韩蜜桃| 人妻丰满AV无码久久不卡| 人妻丰满熟妇AV无码片| 免费看成人AA片无码视频羞羞网| 中文字幕无码亚洲欧洲日韩| 日本无码一区二区三区白峰美|