polcof.c

来自「适合大型数值计算代码 现在网络上已经找不到了 购买需要20$」· C语言 代码 · 共 38 行

C
38
字号
#include <math.h>#define NRANSI#include "nrutil.h"void polcof(float xa[], float ya[], int n, float cof[]){	void polint(float xa[], float ya[], int n, float x, float *y, float *dy);	int k,j,i;	float xmin,dy,*x,*y;	x=vector(0,n);	y=vector(0,n);	for (j=0;j<=n;j++) {		x[j]=xa[j];		y[j]=ya[j];	}	for (j=0;j<=n;j++) {		polint(x-1,y-1,n+1-j,0.0,&cof[j],&dy);		xmin=1.0e38;		k = -1;		for (i=0;i<=n-j;i++) {			if (fabs(x[i]) < xmin) {				xmin=fabs(x[i]);				k=i;			}			if (x[i]) y[i]=(y[i]-cof[j])/x[i];		}		for (i=k+1;i<=n-j;i++) {			y[i-1]=y[i];			x[i-1]=x[i];		}	}	free_vector(y,0,n);	free_vector(x,0,n);}#undef NRANSI

⌨️ 快捷键说明

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