动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > C/C++教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ C/C++教程 ]的信息

本月文章推荐
.unix下编写socket程序的一般步骤.
.几行代码,可画所有函数的图像.
.C++中的运算符重载函数基础及其值.
.解决网爬工具爬取页面信息出现乱.
.教学计划编制问题.
.C++中将ListView中的内容导出到W.
.实例解析C++/CLI的串行化.
.改变打开对话框中"打开&quo.
.C++初学者应该关心的优秀图书一览.
.C++ 扩展和嵌入 Python(1).
.快的马.
.一个画抛物线的程序.
.实现LZARI压缩算法的C++类.
.C++启蒙之编写简单的C++程序.
.高质量C++/C编程指南(八).
.C++ Builder 编写动作.
.循环链表实验.
.指针运算符与指针表达式.
.C++中的 static 关键字.
.API之文本和字体函数.

牛顿和拉格朗日插值算法

发表日期:2008-3-8 |


/*近日浏览文章时发现在这个网站上有好几篇问关于牛顿插值和拉格朗日插值的文章。本人正好写了这个代码,将它公布,希望对一些朋友有帮助。如程序中有什么问题请与我联系。QQ:421404493 E-mail:wbaobao#zj.com*/ //编译平台:2000+vc6.0 //实验一
//作者:计算机科学与技术02级2班 宝宝 421404493
#include<stdio.h>
#include<stdlib.h>
#include<iostream.h>
typedef strUCt data
{
 float x;
 float y;
}Data;//变量x和函数值y的结构
Data d[20];//最多二十组数据
float f(int s,int t)//牛顿插值法,用以返回插商
{
 if(t==s+1)
  return (d[t].y-d[s].y)/(d[t].x-d[s].x);
 else
        return (f(s+1,t)-f(s,t-1))/(d[t].x-d[s].x);  
}
float Newton(float x,int count)
{
 int n;
 while(1)
 {
     cout<<"请输入n值(即n次插值):";//获得插值次数
  cin>>n;
  if(n<=count-1)// 插值次数不得大于count-1次
   break;
  else
   system("cls");
 }
//初始化t,y,yt。
 float t=1.0;
 float y=d[0].y;
 float yt=0.0;
//计算y值
 for(int j=1;j<=n;j++)
 {
  t=(x-d[j-1].x)*t;
  yt=f(0,j)*t;
  //cout<<f(0,j)<<endl;
  y=y+yt;
 }
 return y;
}
float lagrange(float x,int count)
{
 float y=0.0;
 for(int k=0;k<count;k++)//这儿默认为count-1次插值
 {
  float p=1.0;//初始化p
  for(int j=0;j<count;j++)
  {//计算p的值
   if(k==j)continue;//判定是否为同一个数
   p=p*(x-d[j].x)/(d[k].x-d[j].x);
  }
  y=y+p*d[k].y;//求和
 }
 return y;//返回y的值
}
void main()
{
 float x,y;
 int count;
 while(1)
 {
  cout<<"请输入x[i],y[i]的组数,不得超过20组:";//要求用户输入数据组数
  cin>>count;
  if(count<=20)
   break;//检查输入的是否合法
  system("cls");
 }
//获得各组数据
 for(int i=0;i<count;i++)
 {
      cout<<"请输入第"<<i+1<<"组x的值:";
      cin>>d[i].x;
      cout<<"请输入第"<<i+1<<"组y的值:";
      cin>>d[i].y;
   system("cls");
 }
 cout<<"请输入x的值:";//获得变量x的值
 cin>>x;
 while(1)
 {
  int choice=3;
  cout<<"请您选择使用哪种插值法计算:"<<endl;
  cout<<"              (0):退出"<<endl;

  cout<<"              (1):Lagrange"<<endl;
  cout<<"              (2):Newton"<<endl;
  cout<<"输入你的选择:";
  cin>>choice;//取得用户的选择项
  if(choice==2)
  {
   cout<<"你选择了牛顿插值计算方法,其结果为:";
   y=Newton(x,count);break;//调用相应的处理函数
  }
        if(choice==1)
  {
   cout<<"你选择了拉格朗日插值计算方法,其结果为:";
   y=lagrange(x,count);break;//调用相应的处理函数
  }
  if(choice==0)
   break;
  system("cls");
  cout<<"输入错误!!!!"<<endl;
 }
 cout<<x<<"    ,        "<<y<<endl;//输出最终结果
    
}

上一篇:C++计算四则表达式的模板 人气:1468
下一篇:VC++下用MSComm控件实现串口通讯 人气:3652
浏览全部C/C++的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-10-12 team论坛 v2.0.4 bulid 080916 A
2008-10-12 Roclog v3.1.6
2008-10-12 SupeV v1.0.1 简体中文 GBK
2008-10-12 NetCMS v1.6.0.1010 正式版
2008-10-12 PHP考试系统PPFrame v1.2.7
2008-10-12 LPAS个人相册 v1.6.3
2008-10-12 快问仿百度知道系统 动态-静态-互
2008-10-12 方卡广告防点击系统 V1.0 GB2312
2008-10-12 泡菜内容管理系统[PCMS] v1.0 Bu
2008-10-11 联系人分组工具 v1.1 中文破解版
2008-10-11 FaceMelter变脸 v2.0 汉化破解版
2008-10-11 PathTracker道路跟踪仪 v1.2 破解
2008-10-11 Rooms手机聊天室 v0.6.7 破解版
2008-10-11 RemoteDesktop远程桌面 v1.0 破解
2008-10-11 ProRemote远程调音台 v1.0.1 破解
2008-10-11 PicShare照片共享 v1.0.0 破解版
2008-10-11 Photogene照片编辑器 v1.5 汉化破
2008-10-11 WriteRoom共享文档 v1.0 破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | js/vbs加密 | md5加密 | 进制转换 | UTF-8 转换工具 | Html转换js | Html转换asp | Html转换php | Html转换perl
实用工具:汉字翻译拼音 | 拼音字典 | 符号对照表 | 个税计算 | 实时汇率查询换算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 | 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵
SEO対策 中国語教室 ホームページ作成