码迷,mamicode.com
首页 > 编程语言 > 详细

C语言之基本算法24—黄金分割法求方程近似根

时间:2015-07-10 13:34:57      阅读:153      评论:0      收藏:0      [点我收藏+]

标签:c语言   黄金分割法   求方程近似解   

//黄金分割法!
/*
================================================================
题目:用黄金分割法求解3*x*x*x-2*x*x-16=0的根。
================================================================
*/
#include<stdio.h>
#include <math.h>
#define E 1e-8
double hs(double x)
{
return 3*x*x*x-2*x*x-16;
}
double gen(double a,double b)
{
double x,fx,fa,fb,g;
g=(sqrt(5)-1.0)/2;
fa=hs(a);
fb=hs(b);
while(fabs(b-a)>E)
{
x=g*(b-a)+a;
fx=hs(x);
if(fa*fx>0)
{
a=x;
fa=fx;
}
else if(fb*fx>0)
{
b=x;
fb=fx;
}
}
return x;
}
main()
{
double a,b,t,fa,fb;
while(fa*fb>0)
{
printf("输入估计区间:\na=");
scanf("%lf",&a);
printf("输入估计区间:\nb=");
scanf("%lf",&b);
fa=hs(a);
fb=hs(b);
}
t=gen(a,b);
printf("方程:3*x*x*x-2*x*x-16=0\n");
printf("解得:x=%.4lf\n",t);
}


/*
================================================================
评:

黄金分割法效率高,但是对初学者来说编写程序比较麻烦,相比而言穷举法程序编写

简单,但效率低下,不过其适用范围很广,只要给定区间,就可以穷举!对于简单方程

的求解,穷举法很容易实现!在没有办法的情况下,穷举法是可以采取的!

================================================================
*/

版权声明:本文为博主原创文章,未经博主允许不得转载。

C语言之基本算法24—黄金分割法求方程近似根

标签:c语言   黄金分割法   求方程近似解   

原文地址:http://blog.csdn.net/lzx19901012/article/details/46828333

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!