netn0.c

来自「拟牛顿法求非线性方程,并以一组三元二次方程组为例进行求解。」· C语言 代码 · 共 30 行

C
30
字号

  #include "stdio.h"
  #include "netn.c"
  #include "rgauss.c"
  main()
  { int i,k;
    double eps,t,h;
    static double x[3]={1.0,1.0,1.0};
    void  netnf();
    t=0.1; h=0.1; eps=0.0000001; k=100;
    i=netn(3,eps,t,h,x,k,netnf);
    printf("\n");
    printf("i=%d\n",i);
    printf("\n");
    for (i=0; i<=2; i++)
      printf("x(%d)=%13.7e\n",i,x[i]);
    printf("\n");
  }

  void netnf(x,y,n)
  int n;
  double x[],y[];
  { y[0]=x[0]*x[0]+x[1]*x[1]+x[2]*x[2]-1.0;
    y[1]=2.0*x[0]*x[0]+x[1]*x[1]-4.0*x[2];
    y[2]=3.0*x[0]*x[0]-4.0*x[1]+x[2]*x[2];
    n=n;
    return;
  }

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?