BZOJ1013球形空间产生器sphere 高斯消元
@[高斯消元]
Description
有一个球形空间产生器能够在n维空间中产生一个坚硬的球体。现在,你被困在了这个n维球体中,你只知道球
面上n+1个点的坐标,你需要以最快的速度确定这个n维球体的球心坐标,以便于摧毁这个球形空间产生器。
Input
第一行是一个整数\(n(1<=N=10)\)。接下来的\(n + 1\)行,每行有\(n\)个实数,表示球面上一点的\(n\)维坐标。每一个实数精确到小数点
后6位,且其绝对值都不超过\(20000\)。
Output
有且只有一行,依次给出球心的n维坐标(\(n\)个实数),两个实数之间用一个空格隔开。每个实数精确到小数点后\(3\)位。数据保证有解。你的答案必须和标准输出一模一样才能够得分。
Sample Input
2
0.0 0.0
-1.0 1.0
1.0 0.0
Sample Output
0.500 1.500
HINT
提示:给出两个定义:1、 球心:到球面上任意一点距离都相等的点。2、 距离:设两个n为空间上的点A, B的坐标为\((a_1, a_2 .. a_n), (b_1, b_2 .. b_n)\), 则AB的距离定义为:\(dist = \sqrt{(a_1 - b_1) ^ 2 + (a_2 - b_2) ^ 2 + .. + (a_n - b_n) ^ 2}\)
Solution
這題很尷尬的一點就是方程帶有二次項, 而且半徑也尚不能確定.
然而又發現, 這題只有\(n\)個未知數, 但是給了\(n + 1\)個點的座標. 因此, 這一題可以通過作差的方式把二次项降到一次項. 具體來說, 就是:
原式:
\]
\]
作差後:
\]
即
\]
因此\(n - 1\)個座標得到\(n\)個線性方程組, 可以用高斯消元發解決.
至於關於高斯消元發的具體步驟, 直接看代碼就好了.
#include<cstdio>
#include<cctype>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
const int N = 1 << 4;
double f[N];
double equa[N][N];
inline double sqr(double x)
{
return x * x;
}
int main()
{
#ifndef ONLINE_JUDGE
freopen("BZOJ1013.in", "r", stdin);
freopen("BZOJ1013.out", "w", stdout);
#endif
int n;
scanf("%d", &n);
for(int i = 0; i < n; i ++)
scanf("%lf", &f[i]);
memset(equa, 0, sizeof(equa));
for(int i = 0; i < n; i ++)
for(int j = 0; j < n; j ++)
{
double x;
scanf("%lf", &x);
equa[i][j] = 2 * (x - f[j]);
equa[i][n] += sqr(x) - sqr(f[j]);
}
for(int i = 0; i < n; i ++)
{
double mx = - 1.0;
int ID;
for(int j = i; j < n; j ++)
if(fabs(equa[j][i]) > mx)
mx = fabs(equa[j][i]), ID = j;
swap(equa[ID], equa[i]);
for(int j = 0; j < n; j ++)
if(i != j)
for(int k = n; ~ k; k --)
equa[j][k] -= equa[j][i] / equa[i][i] * equa[i][k];
}
for(int i = 0; i < n - 1; i ++)
printf("%.3lf ", equa[i][n] / equa[i][i]);
printf("%.3lf\n", equa[n - 1][n] / equa[n - 1][n - 1]);
}
BZOJ1013球形空间产生器sphere 高斯消元的更多相关文章
- BZOJ-1013 球形空间产生器sphere 高斯消元+数论推公式
1013: [JSOI2008]球形空间产生器sphere Time Limit: 1 Sec Memory Limit: 162 MB Submit: 3662 Solved: 1910 [Subm ...
- bzoj1013球形空间产生器sphere 高斯消元(有系统差的写法
Description 有一个球形空间产生器能够在n维空间中产生一个坚硬的球体.现在,你被困在了这个n维球体中,你只知道球面上n+1个点的坐标,你需要以最快的速度确定这个n维球体的球心坐标,以便于摧毁 ...
- [bzoj1013][JSOI2008][球形空间产生器sphere] (高斯消元)
Description 有一个球形空间产生器能够在n维空间中产生一个坚硬的球体.现在,你被困在了这个n维球体中,你只知道球 面上n+1个点的坐标,你需要以最快的速度确定这个n维球体的球心坐标,以便于摧 ...
- BZOJ 1013: [JSOI2008]球形空间产生器sphere 高斯消元
1013: [JSOI2008]球形空间产生器sphere Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/Judg ...
- lydsy1013: [JSOI2008]球形空间产生器sphere 高斯消元
题链:http://www.lydsy.com/JudgeOnline/problem.php?id=1013 1013: [JSOI2008]球形空间产生器sphere 时间限制: 1 Sec 内 ...
- BZOJ 1013 球形空间产生器sphere 高斯消元
题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1013 题目大意: 有一个球形空间产生器能够在n维空间中产生一个坚硬的球体.现在,你被困 ...
- 【BZOJ 1013】【JSOI2008】球形空间产生器sphere 高斯消元基础题
最基础的高斯消元了,然而我把j打成i连WA连跪,考场上再犯这种错误就真的得滚粗了. #include<cmath> #include<cstdio> #include<c ...
- 【BZOJ1013】球形空间产生器(高斯消元)
[BZOJ1013]球形空间产生器(高斯消元) 题面 Description 有一个球形空间产生器能够在n维空间中产生一个坚硬的球体.现在,你被困在了这个n维球体中,你只知道球 面上n+1个点的坐标, ...
- 【BZOJ1013】[JSOI2008] 球形空间产生器(高斯消元)
点此看题面 大致题意: 给定一个\(n\)维球体上的\(n+1\)个点,请你求出这个球体的圆心的位置. 列出方程 这一看就是一道解方程题. 我们可以设这个球体的圆心的位置为\((x_1,x_2,..x ...
随机推荐
- ACM-ICPC 2018 沈阳赛区网络预赛 F. Fantastic Graph(有源上下界最大流 模板)
关于有源上下界最大流: https://blog.csdn.net/regina8023/article/details/45815023 #include<cstdio> #includ ...
- Linux学习-检验软件正确性
md5sum / sha1sum / sha256sum 目前有多种机制可以计算文件的指纹码,我们选择使用较为广泛的 MD5, SHA1 或 SHA256 加密机 制来处理,我们拿NTP 软件来检查看 ...
- Linux学习-服务器硬件数据的收集
以系统内建 dmidecode 解析硬件配备 系统有个名为 dmidecode 的软件,它可以解析 CPU 型号.主板型号与内存相 关的型号等等~ [root@study ~]# dmidecode ...
- Page-Object思想
为什么要使用page-object 集中管理元素对象 集中管理一个page内的公共方法 后期维护方便 集中管理元素对象 实现方法: 调用方法: WebElement element = dri ...
- HDU 3639 SCC Hawk-and-Chicken
求SCC缩点,统计出每个SCC中的点的个数. 然后统计能到达u的最多的点的个数,可以反向建图,再dfs一遍统计出来. 最后说一下,有必要开一个标记数组,因为测试数据中有重边,结果无限WA. #incl ...
- I love you
while(true) { printf("I love you"); } 字母解析 I-Inject--投入 投入,这个投入有很多概念,有对自己所爱的人,投入自己所有的感情,让你 ...
- Python学习——第一天
https://www.runoob.com/python/python-chinese-encoding.html 第一个python程序 [root@mini1 ~]# vi python01.p ...
- requests与urllib 库
requests库 发送请求: 可以处理所有请求类型:get.post.put.Delete.Head.Options r = requests.get(''https://httpbin.org/' ...
- linux随笔二
1.查看整个文件 cat mongo.sh 查看脚本文件的内容:mongo 172.60.0.203:27017/che001 -uplatform -pplatform cat -n **,查 ...
- 用Python表达对Android的想法
组员:喻航,张子东 视频:点我 #DISCARD ANDROID TODAY! import turtle import turtle as gui #setting turtle.screensiz ...