资源预览内容
第1页 / 共23页
第2页 / 共23页
第3页 / 共23页
第4页 / 共23页
第5页 / 共23页
第6页 / 共23页
第7页 / 共23页
第8页 / 共23页
第9页 / 共23页
第10页 / 共23页
亲,该文档总共23页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述
上机试验1. 秦九韶算法:编程求多项式 P(x)=(0.0625x+0.0425) x+1.912) x+2.1296在x=1.0处旳值。 #include stdio.hmain()static float a=2.1296,1.912,0.0425,0.0625; float y; int i; float x=1.0; clrscr(); y=a3; for (i=2;i=0;i-) y=y*x+ai; printf(x=%4.2f,y=%6.4f,x,y); 2. 二分法:方程f(x)=x3-x-1=0, 运用逐渐搜索法确定一种有根区间。 #include stdio.h#include math.h#define f(x) (x*(x*x-1)-1)#define e 0.005main() int i=0; float x,a=1,b=1.5,y=f(a); if(y*f(b)=0) printf(nThe range is error!); return; else do x=(a+b)/2; printf(nx%d=%6.4f,i,x); i+; if (f(x)=0) break; if(y*f(x)e); printf(nx=%4.2f,x);#include stdio.h#include math.h#define f(x) (x*x-1)*x-1)main() int i; float x,a=1,b=1.5,y=f(a); if(y*f(b)=0) printf(nThe range is error!); return; else for(i=0;i=6;i+)/*次数限制结束*/ x=(a+b)/2; printf(nx%d=%6.4f,i,x); if (f(x)=0) break; if(y*f(x)=0.00005); printf(nx=%6.4f,x1); printf(nf(x)=%6.4f,fabs(x1-pow(10,x1)+2);(2) 求方程x=e-x在0.5附近旳根。#include stdio.h#include math.hmain() float x0,x1=0.5; int i=1; do x0=x1; x1=exp(-x0); printf(nx%d=%7.5f,i,x1); i+; while(fabs(x1-x0)0.001); printf(nx=%5.3f,x1);4.牛顿迭代法:(1) 求方程x=e-x在0.5附近旳根。#include stdio.h#include math.hmain() float x0,x1=0.5; int i=0; printf(nx%d=%7.5f,i,x1); i+; do x0=x1; x1=x0-(x0-exp(-x0)/(1+x0); printf(nx%d=%7.5f,i,x1); i+; while(fabs(x1-x0)=0.001); printf(nx=%5.3f,x1);(2)求方程f(x)=x3-2x2-4x-7=0在3, 4中旳根旳近似值 , 精度规定为=10-2。 #include stdio.h#include math.hmain() float x0,x1=4; int i=0; printf(nx%d=%5.3f,i,x1); i+; do x0=x1; x1=x0-(x0-2)*x0-4)*x0)-7)/(3*x0-4)*x0-4); printf(nx%d=%5.3f,i,x1); i+; while(fabs(x1-x0)=0.01); printf(nx=%4.2f,x1);(3) 计算旳值。#include stdio.h#include math.hmain() float x0,x1=11; do x0=x1; x1=x0-(x0*x0-115)/(2*x0); while(fabs(x1-x0)=0.005); printf(x=%5.2f,x1);1.列主元消去法:求解线性方程组:0.01x1 + 2 x2 - 0.5x3 = - 5 - x1 -0.5x2 + 2x3 = 5 5x1 - 4x2 + 0.5x3 =9 #include stdio.h #include math.h #define n 3 main() int i,j,k; int mi; float mv,tmp; float ann=0.01,2,-0.5,-1,-0.5,2,5,-4,0.5; float bn=-5,5,9,xn; for(k=0;kn-1;k+) mi=k; mv=fabs(akk); for(i=k+1;imv) mi=i; mv=fabs(aik); if(mik) tmp=bk; bk=bmi; bmi=tmp; for(j=k;jn;j+) tmp=akj; akj=amij; amij=tmp; for(i=k+1;in;i+) tmp=aik/akk; bi=bi-bk*tmp; for(j=k+1;j=0;i-) xi=bi; for(j=i+1;jn;j+) xi=xi-aij*xj; xi=xi/aii; printf(nThe result is:); for(i=0;in;i+) printf(nx%d=%4.2f,i,xi); 2.矩阵三角分解法:求解线性方程组x1 + 2 x2 - x3 = 3x1 - x2 + 5x3 = 04x1 + x2 + 2x3= 2#include stdio.h #include math.h #define n 3 main() int i,j,k,r; float s; static float ann=1,2,-1,1,-1,5,4,1,2; static float bn=3,0,2,xn,yn; static float lnn,unn; for(i=0;in;i+) lii=1; for(k=0;kn;k+) for(j=k;jn;j+) s=0; for(r=0;rk;r+) s=s+lkr*urj; ukj=akj-s; for(i=k+1;in;i+) s=0; for(r=0;rk;r+) s=s+lir*urk; lik=(aik-s)/ukk; for(i=0;in;i+) s=0; for(j=0;j=0;i-) s=0; for(j=n-1;j=i+1;j-)s=s+uij*xj; xi=(yi-s)/uii; printf(The result is:); for(i=0;in;i+) printf(nx%d=%5.3f,i,xi); (3) 雅可比迭代法和高斯赛德尔迭代法:求解方程组:10x1 - 2 x2 - x3 = 3-2x1 + 10x2 - x3 = 15-x1 -2 x2 + 5x3= 10#include stdio.h #include math.h #define MAX 100 #define n 3 #define exp 0.005 main() int i,j,k,m; float temp,s; float ann=10,-2,-1,-2,10,-1,-1,-2,5; float static bn=3,15,10; float static xn,Bnn,gn,yn=0,0,0; for(i=0;in;i+) for(j=0;jn;j+) Bij=-aij/aii; gi=bi/aii; for(i=0;in;i+) Bii
收藏 下载该资源
网站客服QQ:2055934822
金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号