bzoj1013 [ JSOI2008 ] -- 高斯消元

Posted gjghfd

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了bzoj1013 [ JSOI2008 ] -- 高斯消元相关的知识,希望对你有一定的参考价值。

得到n+1个方程:

(a1 1-x1)2+(a1 2-x2)2+..+(a1 n-xn)2=r2

(a2 1-x1)2+(a2 2-x2)2+..+(a2 n-xn)2=r2

...

(an+1 1-x1)2+(an+1 2-x2)2+..+(an+1 n-xn)2=r2

将后n个方程减去第一个方程就能到得到n个n个未知数的线性方程,高斯消元即可。

代码:

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<cmath>
 5 using namespace std;
 6 #define N 20
 7 double a[N][N],b[N],x;
 8 int i,j,k,n,m;
 9 inline void Guass(){
10     for(int i=1;i<=n;i++){
11         double Ma=-1;int x;
12         for(int j=i;j<=n;j++)if(fabs(a[j][i])>Ma)Ma=fabs(a[j][i]),x=j;
13         if(x!=i)for(int j=1;j<=n+1;j++)swap(a[i][j],a[x][j]);
14         double t=a[i][i];
15         for(int j=1;j<=n+1;j++)a[i][j]/=t;
16         for(int j=1;j<=n;j++)
17         if(i!=j){
18             double t=a[j][i];
19             for(int k=1;k<=n+1;k++)
20             a[j][k]-=t*a[i][k];
21         }
22     }
23 }
24 int main()
25 {
26     scanf("%d",&n);
27     for(i=1;i<=n;i++)scanf("%lf",&b[i]);
28     for(i=1;i<=n;i++){
29         for(j=1;j<=n;j++)
30         scanf("%lf",&x),a[i][j]=(x-b[j])*2,a[i][n+1]+=x*x-b[j]*b[j];
31     }
32     Guass();
33     for(printf("%.3lf",a[1][n+1]),i=2;i<=n;i++)printf(" %.3lf",a[i][n+1]);
34     return 0;
35 }
bzoj1013

 

以上是关于bzoj1013 [ JSOI2008 ] -- 高斯消元的主要内容,如果未能解决你的问题,请参考以下文章

BZOJ1013: [JSOI2008]球形空间产生器sphere

BZOJ 1013: [JSOI2008]球形空间产生器sphere

bzoj 1013: [JSOI2008]球形空间产生器sphere

bzoj1013 [JSOI2008]球形空间产生器sphere

BZOJ 1013: [JSOI2008]球形空间产生器sphere 高斯消元

bzoj1013 JSOI2008—球形空间产生器sphere