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 ...
随机推荐
- stm32L0工程建立(HAL+IAR,无cubemx)
https://files.cnblogs.com/files/CodeWorkerLiMing/STM32HAL%E5%BA%93%E5%AD%A6%E4%B9%A0%E2%80%94%E5%B7% ...
- 图上两点之间的第k最短路径的长度 ACM-ICPC 2018 沈阳赛区网络预赛 D. Made In Heaven
131072K One day in the jail, F·F invites Jolyne Kujo (JOJO in brief) to play tennis with her. Howe ...
- MIP启发式算法:Variable Neighborhood Decomposition Search
*本文记录和分享学习到的知识,算不上原创. *参考文献见链接. 本文主要简述和VND VNS RINS很相关的vairable neighborhood decomposition search. 目 ...
- selenium2 页面对象模型Page Object
开发Selenium WebDriver测试时,可以使用页面对象模型,这样可使得测试脚本有更高的可维护性,减少了重复的代码,把页面抽象出来.同时页面对象模型也提供了一个注释,帮助缓存远程,避免出现元素 ...
- Linux网络编程:客户端/服务器的简单实现
一. Socket的基本知识 1. socket功能 Socket层次 Socket实质上提供了进程通信的端点,进程通信之前,双方必须首先各自创建一个端点,否则是没有办法建立联系并相互通信的. 每一个 ...
- 如何将Python对象保存在本地文件中?
Python对象的永久存储 1.使用Python的pickle模块 import pickle class A: def __init__(self,name,a): self.name=name s ...
- LOFTER 迁移
title: LOFTER 迁移 date: 2018-09-01 16:41:02 updated: tags: [其他] description: keywords: comments: imag ...
- sql获取指定表所有列名及注释
SELECT b.name as 字段名 ,Type_name(b.xusertype) as 字段类型, Isnull(c.VALUE,'') as 字段说明FROM sysobjects a jo ...
- python 学习分享-字典篇
python字典(Dictionary) dict是无序的 key必须是唯一切不可变的 a={'key1':'value1','key2':'value2'} 字典的增删改查 a['key3']='v ...
- php 操作excel
<?php $dir=dirname(__FILE__);//查找当前脚本所在路径 require $dir."/db.php";//引入mysql操作类文件 require ...