📄 pzextr.c
字号:
extern float **d,*x; /* defined in BSSTEP */
void pzextr(iest,xest,yest,yz,dy,nv,nuse)
int iest,nv,nuse;
float xest,yest[],yz[],dy[];
{
int m1,k1,j;
float q,f2,f1,delta,*c,*vector();
void free_vector();
c=vector(1,nv);
x[iest]=xest;
for (j=1;j<=nv;j++) dy[j]=yz[j]=yest[j];
if (iest == 1) {
for (j=1;j<=nv;j++)
d[j][1]=yest[j];
} else {
m1=(iest < nuse ? iest : nuse);
for (j=1;j<=nv;j++) c[j]=yest[j];
for (k1=1;k1<=m1-1;k1++) {
delta=1.0/(x[iest-k1]-xest);
f1=xest*delta;
f2=x[iest-k1]*delta;
for (j=1;j<=nv;j++) {
q=d[j][k1];
d[j][k1]=dy[j];
delta=c[j]-q;
dy[j]=f1*delta;
c[j]=f2*delta;
yz[j] += dy[j];
}
}
for (j=1;j<=nv;j++) d[j][m1]=dy[j];
}
free_vector(c,1,nv);
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -