|
|
# include
# include
void main()
{
float m,A[9];
float L[6];
printf("请输入矩阵: \n " ;
scanf("%f %f %f\n%f %f %f\n%f %f %f\n",&A[0],&A[1],&A[2],&A[3],&A[4],&A[5],&A[6],&A[7],&A[8]);
printf("请输入�许误差:m=" ;
scanf("%f",&m);
if
A[0]>m&&(A[0]*A[4]-A[1]*A[3]>m)&&(A[6]*A[4]*A[2]+A[0]*A[7]*A[5]+A[1]*A[3]*A[8]-A[0]*A[4]*A[8]-A[1]*A[6]*A[5]-A[2]*A[3]*A[7]>m)&&(A[1]==A[3])&&(A[2]==A[6])&&(A[5]==A[7])
{
L[0]=sqrt(A[0]);
L[1]=A[3]/L[0];
L[3]=A[6]/L[0];
L[2]=sqrt(A[4]-L[1]*L[1]);
L[4]=(A[7]-L[3]*L[1])/L[2];
L[5]=sqrt(A[8]-L[3]*L[3]-L[4]*L[4]);
printf("所求矩阵为L=\n %f 0 0\n%f %f 0\n%f %f %f\n",L[0],L[1],L[2],L[3],L[4], L[5]);
}
else
printf("输入有误,请检查" ;
}
调试�行:
1>.\Debug\shiyan.exe.intermediate.manifest : general error c1010070: Failed to load and parse the manifest. {_~0p'1a@'7v par 1>Build log was saved at "file://e:\360data\��数�\桌�\shiyan\shiyan\Debug\BuildLog.htm"
1>shiyan - 1 error(s), 0 warning(s)
========== Rebuild All: 0 succeeded, 1 failed, 0 skipped ==========
å·¥ç¨‹æ— æ³•å»ºç«‹
预期效果:
请输入矩阵:
1 2 3
2 4 5
3 5 6
请输入�许误差:m=1e-6
输入有误,请检查
请输入矩阵:
5 2 -4
2 1 -2
-4 -2 5
请输入�许误差:m=1e-6
所求矩阵L=
2.236068 0 0
0.894427 0.4472136 0
-1.788854 -0.894427 1
我的算法è¿?行ä¸?é€šè¿‡å•Šï¼Œè€Œä¸”æ ¹æœ¬æœªèƒ½å®žçŽ°é’ˆå¯¹ä»»æ„?阶次的矩阵。。。求大神帮忙~ |
|