数值计算编程作业.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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)

kaiss + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档