- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数值计算编程作业
数值计算作业
\
一. 为求方程X3-X2-1=0在X0=1.5附近的一个根,设将方程写
成X=1+1/X2,迭代格式为Xi+1=1+1/Xi2。
解:#includestdio.h
main()
{long float x,x0;
X0=1.5;
While(fab(x-x0)1e-3)
{x=1+1/x0*x0;
x0=x;}
printf(“x=%lf\n”,x);}
运行结果:x=1.465
二.用牛顿法求f(x)=x3-3x-1=0在x0=2附近的根,要求有
四位有效数字。
解:#includestdio.h
#includemath.h
main()
{long float x,x0,f,f1;
X=2.0;
do{x0=x;
f=x0*x0*x0-3*x0-1;
f1=3*x0*x0-3;
x=x0-f/f1;}
while(fabs(x-x0)=1e-4);
printf(“The root of the EQU is%6.3lf\n”,x);}
运行结果:The root of the EQU is1.879
三. 用消去法解方程组
2x1+2x2+3x3=3 ①
4x1+7x2+7x3=1 ②
-2x1+4x2+5x3=-7 ③
解:#includeiostream
#includecmath
#define N 20
using namespace std;
void load();
float a[N][N];
int m;
m=3;
int main()
{int i,j,m;
int c,k,n,p,r;
float x[N],l[N][N],s,d;
coutendl;
cout请按顺序输入增广矩阵a:endl;
load();
for(i=0;im;i++)
{for(j=i;jm;j++)
c=(fabs(a[j][i])fabs(a[i][i]))?j:i;
for(n=0;nm+1;n++)
{s=a[i][n]; a[i][n]=a[c][n]; a[c][n]=s;}
for(p=0;pm+1;p++)
couta[i][p]\t;
coutendl;
for(k=i+1;km;k++)
{l[k][i]=a[k][i]/a[i][i];
for(r=i;rm+1;r++) a[k][r]=a[k][r]-l[k][i]*a[i][r];} }
x[m-1]=a[m-1][m]/a[m-1][m-1];
for(i=m-2;i=0;i--)
{d=0;
for(j=i+1;jm;j++)
d=d+a[i][j]*x[j];
x[i]=(a[i][m]-d)/a[i][i];}
cout该方程组的解为:endl;
for(i=0;im;i++)
coutx[i]=x[i]\t;
//system(pause);
return 0;}
void load()
{int i,j;
for(i=0;im;i++)
for(j=0;jm+1;j++)
cina[i][j];}
请按顺序输入增广矩阵a:
2 2 3 3
4 7 7 1
-2 4 5 -7
4 7 7 1
0 -1.5 -0.5 3
0 7.5 8.5 -7
运行结果:该方程组的解为:x[0]=2 x[1]=-2 x[2]=1
四.用梯形公式求∫19x1/2dx的积分。
解:#includestdio.h
#includemath.h
doublef(double x)
{return (sqrt x);}
double T(double a,double b)
{double m,n;
h=(b-a)/2,n=f(a)+f(b);
Return(m*n);}
main()
{double a,b;
a=1,b=9;
double T(double a,double b);
printf(“%lf”,T(a,b));}
运行结果:16
五.取步长h=0.2用龙格-库塔格式解初值问题。
y’=x+y 0≤x≤0.6
{y (0)=1
解:#includestdio.h
#includemath.h
#define f(x,y),x+y;
main()
{int n,k=1;
long float a,b,h,x,y,y0,t[4];
scanf(“%lf,%lf,%lf,%lf”,a,b,y0,h);
n=(b-a)/h;
x=a;
y=y0;
printf(“%l
文档评论(0)