国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

Codevs 1038 一元三次方程求解 NOIP 2001(導(dǎo)數(shù) 牛頓迭代)

2019-11-11 04:55:34
字體:
供稿:網(wǎng)友

1038 一元三次方程求解 2001年NOip全國聯(lián)賽提高組 時間限制: 1 s 空間限制: 128000 KB 題目等級 : 白銀 Silver 題目描述 Description 有形如:ax3+bx2+cx+d=0 這樣的一個一元三次方程。給出該方程中各項的系數(shù)(a,b,c,d 均為實數(shù)),并約定該方程存在三個不同實根(根的范圍在-100至100之間),且根與根之差的絕對值>=1。要求由小到大依次在同一行輸出這三個實根(根與根之間留有空格),并精確到小數(shù)點后2位。 提示:記方程f(x)=0,若存在2個數(shù)x1和x2,且x1

/*導(dǎo)數(shù)+勘根定理+牛頓迭代.先對函數(shù)求導(dǎo),f'(x)=3ax^2+2*bx+c.然后直接求根公式求f'(x)=0的點,也就是函數(shù)極點.(我們可以順便求一下凸形函數(shù)極值hhh)這題保證有三個不定根,所以有兩個單峰. 我們分別設(shè)這兩個點為p,q.然后顯然的必有三個根分別在[-100,p),[p,q],(q,100]三個區(qū)間內(nèi)(兩極點間必定存在零點,勘根定理).然后用神奇的牛頓迭代法多次迭代就好了.證明請自行百度,本蒟蒻只能感性的認識orz.*/#include<iostream>#include<cstdio>#include<cmath>#define eps 1e-4using namespace std;double x1,x2,x3,a,b,c,d;double f(double x){return a*x*x*x+b*x*x+c*x+d;}double df(double x){return 3*a*x*x+2*b*x+c;}double slove(double l,double r){ double x,x0=(l+r)/2; while(abs(x0-x)>eps) x=x0-f(x0)/df(x0),swap(x0,x); return x;}int main(){ cin>>a>>b>>c>>d; double p=(-b-sqrt(b*b-3*a*c))/(3*a); double q=(-b+sqrt(b*b-3*a*c))/(3*a); x1=slove(-100,p),x2=slove(p,q),x3=slove(q,100);
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 吴忠市| 吉安市| 绥滨县| 土默特右旗| 尉氏县| 宁武县| 叙永县| 厦门市| 湾仔区| 策勒县| 分宜县| 南开区| 应城市| 辽宁省| 蒙山县| 曲麻莱县| 北宁市| 钟祥市| 桐乡市| 周口市| 饶平县| 永丰县| 普兰县| 永春县| 于田县| 磐石市| 荣昌县| 昆山市| 曲麻莱县| 龙游县| 竹溪县| 镇远县| 昌吉市| 监利县| 绩溪县| 句容市| 米脂县| 鹤岗市| 张家港市| 石渠县| 仙桃市|