- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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
您可能关注的文档
最近下载
- 食管炎演示课件.pptx VIP
- 安徽临泉县发现一件珍贵的谢氏文物——光绪五年诏书.pdf VIP
- 中考语文真题分项汇编(全国通用)专题07 文言文阅读(第02期)(解析版).docx VIP
- 全科医学SOAP病例范例【21页】.pptx VIP
- 北师大版八年级上册第二章3.1确定位置 教案.docx VIP
- 中药配方颗粒质量标准与市场创新产品开发研究报告.docx VIP
- 中考语文真题分项汇编(全国通用)专题03句子(第02期)(原卷版+解析).docx VIP
- 国外页岩气压裂技术进展.pptx VIP
- 《早期诊断胰腺癌的策略与方法》课件.ppt VIP
- 四川省2024年普通高等学校高职教育单独招生文化考试(普高类)语文真题及答案解析(真题解析版).docx VIP
文档评论(0)