拉格朗日c语言实验报告,拉格朗日(Lagrange)插值法(C语言)

编程入门 行业动态 更新时间:2024-10-08 08:34:06

拉格朗日c<a href=https://www.elefans.com/category/jswz/34/1770116.html style=语言实验报告,拉格朗日(Lagrange)插值法(C语言)"/>

拉格朗日c语言实验报告,拉格朗日(Lagrange)插值法(C语言)

题目

拉格朗日插值法流程图

(1)二次插值:

#include

float lagelangri(float x[],float y[],float xx,int n)

{

int i,j;

float *a,yy=0;

a=new float[n];

for(i=0;i<=n-1;i++)

{

a[i]=y[i];

for(j=0;j<=n-1;j++)

if(j!=i)a[i]*=(xx-x[j])/(x[i]-x[j]);

yy+=a[i];

}

delete a;

return yy;

}

void main()

{

float x[5]={-3.0,-1.0,1.0,2.0,3.0};

float y[5]={1.0,1.5,2.0,2.0,1.0};

float xx1=-2,xx2=0,xx3=2.75,yy1,yy2,yy3;

yy1=lagelangri(x,y,xx1,3);

yy2=lagelangri(x,y,xx2,3);

yy3=lagelangri(x,y,xx3,3);

printf("x1=%-20f,y1=%f\n",xx1,yy1);

printf("x2=%-20f,y2=%f\n",xx2,yy2);

printf("x3=%-20f,y3=%f\n",xx3,yy3);

}

(2)五次插值:

#include

float lagelangri(float x[],float y[],float xx,int n)

{

int i,j;

float *a,yy=0;

a=new float[n];

for(i=0;i<=n-1;i++)

{

a[i]=y[i];

for(j=0;j<=n-1;j++)

if(j!=i)a[i]*=(xx-x[j])/(x[i]-x[j]);

yy+=a[i];

}

delete a;

return yy;

}

void main()

{

float x[6]={0.30,0.42,0.50,0.58,0.66,0.72};

float y[6]={1.04403,1.08462,1.11803,1.15603,1.19817,1.23223};

float xx1=0.46,xx2=0.55,xx3=0.60,yy1,yy2,yy3;

yy1=lagelangri(x,y,xx1,6);

yy2=lagelangri(x,y,xx2,6);

yy3=lagelangri(x,y,xx3,6);

printf("x1=%-20f,y1=%f\n",xx1,yy1);

printf("x2=%-20f,y2=%f\n",xx2,yy2);

printf("x3=%-20f,y3=%f\n",xx3,yy3);

}

更多推荐

拉格朗日c语言实验报告,拉格朗日(Lagrange)插值法(C语言)

本文发布于:2024-02-13 11:14:48,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1758100.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:语言   格朗   插值   报告   Lagrange

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!