X

Y

0.40

0.41075

0.55

0.57815

0.65

0.69675

0.80

0.88811

0.90

1.02652

1.05

1.25382

#include

using namespace
std;

double
average_deviation(double* function_value,double*
independent_variable,int
end);     
//声明均差函数

int main()

{

double
x[5]={0.40,0.55,0.65,0.80,0.90};     
//用来存储已知x的值

double
y[5]={0.41075,0.57815,0.69675,0.88811,1.02652};     
//用来存储已知y的值

double
result=0;     
//用来保存最后的插值结果

double
input_x;     
//插值的x值

double
polynomial;     
//保存多项式的值

cout<<"通过插值得到的函数为:"<<endl;

for (int i=0;i<5;i++)

{

cout<<average_deviation(y,x,i);

for (int j=0;j

cout<<"*"<<"("<<"x-"<<x[j]<<")";

if (i<4)

cout<<"+";

}

cout<<endl;

cout<<"请输入插值的x值:";

cin>>input_x;

for (int i=0;i<5;i++)

{

polynomial=1;

for (int j=0;j

{

polynomial*=(input_x-x[j]);

}

result+=(average_deviation(y,x,i)*polynomial);

}

cout<<"插值得到的函数值为:"<<result<</span><</span>endl;

return 0;

}

double
average_deviation(double* function_value,double*
independent_variable,int end)

{

double*
function_value_f;     
//function_value_f用来保存0到k-1的k阶均差

double*
function_value_b;     
//function_value_f用来保存1到k的k阶均差

double*
independent_variable_f;     
//用来保存前k-1个值

double*
independent_variable_b;     
//用来保存后k-1个值

double value_f;

double value_b;

if (0==end)

{

return function_value[end];

}

else

{

function_value_f=new double[end];

independent_variable_f=new double[end];

function_value_b=new double[end];

independent_variable_b=new double[end];

for (int i=1;i<=end;i++)

{

function_value_f[i-1]=function_value[i];

independent_variable_f[i-1]=independent_variable[i];

}

for (int i=0;i<=end-1;i++)

{

function_value_b[i]=function_value[i];

independent_variable_b[i]=independent_variable[i];

}

value_f = average_deviation(function_value_f,
independent_variable_f, end - 1);

value_b = average_deviation(function_value_b,
independent_variable_b, end - 1);

delete[] function_value_f;

delete[] function_value_b;

delete[] independent_variable_b;

delete[] independent_variable_f;

return
(value_f-value_b)/(independent_variable[end]-independent_variable[0]);

}

}

牛顿插值法(c++)的更多相关文章

  1. 牛顿插值法——用Python进行数值计算

    拉格朗日插值法的最大毛病就是每次引入一个新的插值节点,基函数都要发生变化,这在一些实际生产环境中是不合适的,有时候会不断的有新的测量数据加入插值节点集, 因此,通过寻找n个插值节点构造的的插值函数与n ...

  2. 牛顿插值法及其C++实现

    h1 { margin-bottom: 0.21cm } h1.western { font-family: "Liberation Sans", sans-serif; font ...

  3. Matlab数值计算示例: 牛顿插值法、LU分解法、拉格朗日插值法、牛顿插值法

    本文源于一次课题作业,部分自己写的,部分借用了网上的demo 牛顿迭代法(1) x=1:0.01:2; y=x.^3-x.^2+sin(x)-1; plot(x,y,'linewidth',2);gr ...

  4. 牛顿插值法(c++)【转载】

    摘自<c++和面向对象数值计算>,代码简洁明快,采用模板函数,通用性增强,牛顿差分合理利用存储空间,采用Horner算法(又称秦九韶算法)提高精度,减少时间复杂度,高!确实是高!对其中代码 ...

  5. 差分形式的牛顿插值法(c++)

    本程序对cosx函数进行插值,取步长为0.1,因此x的值为0.00,0.10,0.20,0.30,对应的y值为cos(0.00),cos(0.10),cos(0.20),cos(0.30),其实本程序 ...

  6. CPP,MATLAB实现牛顿插值

    牛顿插值法的原理,在维基百科上不太全面,具体可以参考这篇文章.同样贴出,楼主作为初学者认为好理解的代码. function p=Newton1(x1,y,x2) %p为多项式估计出的插值 syms x ...

  7. 埃尔米特插值问题——用Python进行数值计算

    当插值的要求涉及到对插值函数导数的要求时,普通插值问题就变为埃尔米特插值问题.拉格朗日插值和牛顿插值的要求较低,只需要插值函数的函数值在插值点与被插函数的值相等,以此来使得在其它非插值节点插值函数的值 ...

  8. 风景区的面积及道路状况分析问题 test

    参考文献:   https://wenku.baidu.com/view/b6aed86baf1ffc4ffe47ac92.html #include <bits/stdc++.h> us ...

  9. ORACLE SQL 实现IRR的计算

    一.IRR计算的原理: 内部收益率(Internal Rate of Return (IRR)),就是资金流入现值总额与资金流出现值总额相等.净现值等于零时的折现率. 用公式 标识:-200+[30/ ...

随机推荐

  1. 一文读懂内网、公网和NAT

    我们做弱电监控系统的时候,都避免不了要跟IP地址打交道,比如摄像头.NVR.服务器等这些设备安装好之后,就需要给它们配上IP,那这个IP地址你了解嘛?今天我们就一起来聊聊什么是内网.公网和NAT地址转 ...

  2. writeAsBytes writeAsString

    import 'dart:io';import 'dart:convert'; main()async{ File a = File('C:\\aria2\\1.txt'); var c = read ...

  3. 【转载】C#中使用double.Parse方法将字符串转换为双精度double类型

    在C#编程过程中,很多时候涉及到数据类型的转换,例如将字符串类型的变量转换为双精度浮点类型double就是一个常见的类型转换操作,double.Parse方法是C#中专门用来将字符串转换为double ...

  4. Java 之 Response 对象

    Response 对象 一.Response 原理和继承结构 原理和继承结构参考 request. 二.Response 对象 Response 就是用来设置响应消息. 1.设置响应行   响应头格式 ...

  5. Android为TV端助力之热修复原理

    通过源码我们知道Android加载类是通过ClassLoad类里面的findClass先去查找的,如下图所示 通过看源码我们知道,ClassLoad是一个抽象类,它本身并没有实现findclass() ...

  6. MySQL 5.7的复制架构,在有异步复制、半同步、增强半同步、MGR等的生产中,该如何选择?

    一.生产环境中: 几种复制场景都有存在的价值.下面分别描述一下: 从成熟度上来选择,推荐:异步复制(GTID+ROW) 从数据安全及更高性能上选择:增强半同步 (在这个结构下也可以把innodb_fl ...

  7. 你真的理解CountDownLatch与CyclicBarrier使用场景吗?

    原文:https://blog.csdn.net/zzg1229059735/article/details/61191679 相信每个想深入了解多线程开发的Java开发者都会遇到CountDownL ...

  8. ArcGIS pro 发布地图服务(一)动态地图服务

    1.软件:arcgis pro 2.4  数据:.mxd文档. 2.导入mxd文档. 3.登录portal账号 4.分析—发布 5.在server中的地图服务 JavaScript api 查看 6. ...

  9. TPA测试项目管理系统-测试用例管理

            Test Project Administrator(简称TPA)是经纬恒润自主研发的一款专业的测试项目管理工具,目前已广泛的应用于国内二十余个整车厂和零部件供应商.它可以管理测试过程 ...

  10. [转]Linux-虚拟网络设备-tun/tap

    转: 原文:https://blog.csdn.net/sld880311/article/details/77854651 ------------------------------------- ...