编程 利用不动点迭代法求非线性方程的根

编写程序:利用不动点迭代法求解非线性方程的近似根:e^x+10x-2=0... 编写程序:利用不动点迭代法求解非线性方程的近似根:
e^x+10x-2=0
展开
百度网友28b4182
2011-12-31 · TA获得超过7224个赞
知道大有可为答主
回答量:4847
采纳率:100%
帮助的人:2238万
展开全部
此方程可化为e^x=-10x+2
画一下图,既可知道,这直线和这个曲线会有一个交点
假设解为X0
那么从图中可以看出
当X<X0时,e^x<-10x+2
当X>X0时,e^x>-10x+2
那么我们就可以先找两个点,一个是使这个式子是小于号,另一个是使这个式子是大于号的
我们取0和1
那么我们可以二分一个值,然后跟据e^x和-10x+2的关系来调整这个值,最后就可以逼近近似解了
#include<stdio.h>
#include<string.h>
#include<math.h>

int main()
{
double low=0,high=1;
double mid;
int test=100;
double tmp;
while(test--)
{
mid=(low+high)/2;
tmp=exp(mid)+10*mid-2;
if(tmp<0)
{
low=mid;
}
else
{
high=mid;
}
}
printf("X=%lf\n",low);
mid=low;
tmp=exp(mid)+10*mid-2;
printf("验证结果:%lf\n",fabs(tmp));
return 0;
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式