c语言不动点求解函数零点 怎么计算函数不动点

c语言函数求解。。。

#includestdio.h

尼木网站建设公司创新互联建站,尼木网站设计制作,有大型网站制作公司丰富经验。已为尼木1000多家提供企业网站建设服务。企业网站搭建\外贸网站建设要多少钱,请找那个售后服务好的尼木做网站的公司定做!

int main()

{

int (*p)(int a,int b); /*定义P为一个指针,指向一个接受两个int参数返回int的函数*/

int a,b,maxi;

int max(int a,int b);

scanf("%d,%d",a,b);

p=max;

maxi=p(a,b); /*()的优先级高于*,所以你那样写相当于重新解引用了。(*p)(a,b)这样也可以*/

printf("%d",maxi);

return 0;

}

int max(int a,int b)

{

int c;

c=ab?a:b;

return(c);

}

求助C语言二分法求函数零点

#include stdio.h

#include math.h

double fun_math(double);

int main(void)

{

/*  根据函数可知Y是关于x的一个递增函数 */

/*  先判断输入Y时,X在(0,1)时是否有解 */

double Y;

double X=0 ,big_x=1.0,small_x=0,tmp_X=1;

unsigned int tmp=0;

printf("Please enter Y:");

scanf("%lf",Y);

if(fun_math(1) = Y fun_math(0) = Y)

{

while(tmp_X != X)

{

X =(big_x + small_x)/2;

if(fun_math(X)==Y) break;

if(fun_math(X)Y) big_x = X;

else small_x = X;

tmp_X = X ;

X =(big_x + small_x)/2;

}

printf("X = %.6lf",X);

}

else printf("while Y=%lf, X(0,1) on results\n",Y);

return 0;

}

怎么通过C语言实现用不动点迭代方法解超越方程 x = 2 sin x的根,求指点

显然0是方程的根,然后用牛顿法,从1.0和-1.0去迭代

得到1.895494 和-1.895494两个解

验证一下

#include stdio.h

#include math.h

#define DX 0.001

double g(double x) {

return 2 * sin(x) - x;

}

double Dg(double x) {

return (g(x + DX) - g(x)) / DX;

}

double f(double x) {

return x - (g(x) / Dg(x));

}

int good(double a, double b) {

return fabs(a - b) 0.0000001;

}

double fixpoint(double x) {

double next = f(x);

if (good(next, x))

return next;

else

return fixpoint(next);

}

int main() {

printf("%f\n", fixpoint(1.0));

printf("%f\n", fixpoint(-1.0));

return 0;

}


当前名称:c语言不动点求解函数零点 怎么计算函数不动点
文章源于:http://myzitong.com/article/ddiphhp.html