《数值分析》上机题.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
《数值分析》上机实习题 秦九韶算法 1.源程序 #includestdio.h #includeiostream.h //输出文件指针 FILE *stream = NULL; typedef float * pFloat; //和用户交互输入多项式各系数 bool InputParam(int n,pFloat a,float x) { cout秦九韶算法\n; cout请输入最高次数n:; cinn; if(n=0) return false; a = new float[n+1]; for(int i=0;i=n;i++) { cout请输入a[i]:; cina[i]; } cout请输入x的值:; cinx; return true; } //按照格式打印多项式到文件中 void OutputTheMultinomial(int n,pFloat a,float x) { fprintf(stream,此多项式为:\n); fprintf(stream,P(x)=); for(int i=n;i=2;i--) { fprintf(stream,(%f)*x**%d+,a[i],i); } fprintf(stream,(%f)*x+(%f)\n,a[1],a[0]); fprintf(stream,x=%f,x); } //根据多项式各系数及给定的x值计算 float QinJiuShao(int n,pFloat a,float x) { float r=a[n]; for(int i=n-1;i=0;i--) { r = x*r+a[i]; } return r; } //计算第一题 void Calculate1() { fprintf(stream,秦九韶计算结果1\n); int n = 0; float *a = NULL;//指向存放多项式系数的指针 float x = 0; char next = Y; //和用户交互进行输入并计算 while(next == Y || next == y) { if(InputParam(n,a,x)) { //输出多项式 OutputTheMultinomial(n,a,x); //输出结果 fprintf(stream,\n计算结果为:P(%f)=%f\n,x,QinJiuShao(n,a,x)); if(a) { delete []a; a=NULL; } } cout是否进行下一次运算?(Y/N):; cinnext; } } //计算第二题 void Calculate2() { fprintf(stream,秦九韶计算结果2\n); //多项式系数 float a[] = {2.0f,-3.36f,2.81f,-2.74f,-3.27f,0.22f}; int n = 5; float x = 0; //按每次递增0.05计算 for(int i = 0;i = 20;i++) { x=0.8+0.05*i; //输出多项式 OutputTheMultinomial(n,a,x); //输出结果 fprintf(stream,\n计算结果为:P(%f)=%f\n,x,QinJiuShao(n,a,x)); } } void main() { //打开输出结果文件 if((stream = fopen( result.txt, w )) == NULL ) { printf( 打不开输出文件\n ); return; } //通过用户输入计算第一题 Calculate1(); //通过循环生成 x值计算第二题 Calculate2(); //关闭文件 if(stream) fclose(stream); } 2.输出结果 秦九韶计算结果1 此多项式为: P(x)=(7.540000)*x**4+(11.080000)*x**3+(3.820000)*x**2+(0.440000)*x+(-0.480000) x=3.250000 计算结果为:P(3.250000)=1262.865112 此多项式为: P(x)=(2.790000)*x**4+(9.850000)*x**3+(14.150000)*x**2+(5.380000)*x+(7.240000) x=3.250000 计算结果为:P(3.250000)=823.586670 此多项式为: P(x)=(9.3600

文档评论(0)

书是爱的奉献 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档