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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了bzoj 1013: [JSOI2008]球形空间产生器sphere相关的知识,希望对你有一定的参考价值。

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cmath>
 4 #define eps 1e-6
 5 #define M 15
 6 using namespace std;
 7 double a[M],b[M][M];
 8 int n;
 9 int main()
10 {
11     scanf("%d",&n);
12     for(int i=1;i<=n;i++)
13       scanf("%lf",&a[i]);
14     for(int i=1;i<=n;i++)
15       for(int j=1;j<=n;j++)
16         {
17             double t;
18             scanf("%lf",&t);
19             b[i][j]=2*(t-a[j]);
20             b[i][n+1]+=t*t-a[j]*a[j]; 
21         }
22     for(int i=1;i<=n;i++)
23       {
24         int to;
25         for(to=i;to<=n;to++)
26           if(b[to][i]!=0)
27             break;
28         if(i!=to)
29           for(int j=1;j<=n+1;j++)
30             swap(b[i][j],b[to][j]);
31         double t=b[i][i];
32         for(int j=i;j<=n+1;j++)
33           b[i][j]/=t;
34         for(int j=1;j<=n;j++)
35           if(j!=i)
36             {
37                 t=b[j][i];
38                 for(int k=1;k<=n+1;k++)
39                   b[j][k]-=t*b[i][k];
40             }
41       }
42     for(int i=1;i<n;i++)
43       printf("%.3lf ",b[i][n+1]);
44     printf("%.3lf\n",b[n][n+1]);
45     return 0;
46 }

先假设是二维的,设圆心为(x,y),那(x1-x)^2+(y1-y)^2=(xk-x)^2+(yk-y)^2

这样n+1个点就能构造出n个方程  然后高斯消元。(高斯消元不会的看看代码就知道了)

以上是关于bzoj 1013: [JSOI2008]球形空间产生器sphere的主要内容,如果未能解决你的问题,请参考以下文章

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

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

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

bzoj1013 [JSOI2008]球形空间产生器sphere (高斯消元)

BZOJ1013:[JSOI2008]球形空间产生器——题解

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