⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 有理函数插值.cpp

📁 用C++编写的多项式插值算法和有理函数插值算法!
💻 CPP
字号:
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/*********************************本算法由PRINCETH倾情提供!欢迎提宝贵意见*****************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
/******************************************************************************************************************************/
void ratint(double xa[],double  ya[], int n,double x, double& y, double& dy)
{
	int i,ns,m;
	double tiny,w,h,hh,dd,t,c[10], d[10];
    tiny = 1e-25;
    ns = 1;
    hh = fabs(x - xa[1]);
    for( i = 1; i<=n; i++)
	{
        h = fabs(x - xa[i]);
        if (h ==0.0 )
			{
				y = ya[i];
				dy = 0.0;
				return;
			}
        else if( h < hh )
			{
				ns = i;
				hh = h;
			}
        c[i] = ya[i];
        d[i] = ya[i] + tiny;
	}
    y = ya[ns];
    ns = ns - 1;
    for( m = 1; m<=n-1; m++)
	{
        for(i = 1; i<=n-m; i++)
		{
            w = c[i + 1] - d[i];
            h = xa[i + m] - x;
            t = (xa[i] - x) * d[i] / h;
            dd = t - c[i + 1];
            if (dd == 0.0)
				{
					 cout<<"pause"<<endl;
					 return;
				}
            dd = w / dd;
            d[i] = c[i + 1] * dd;
            c[i] = t * dd;
        }
        if (2 * double(ns) <double( n - m) )
		{
            dy = c[ns + 1];
		}
        else 
			
		{
            dy = d[ns];
            ns = ns - 1;
		}
        
        y = y + dy;
    }
}

⌨️ 快捷键说明

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