BZOJ 1013 cogs 1845 [JSOI2008]球形空间产生器sphere
题目描述
有一个球形空间产生器能够在n维空间中产生一个坚硬的球体。现在,你被困在了这个n维球体中,你只知道球
面上n+1个点的坐标,你需要以最快的速度确定这个n维球体的球心坐标,以便于摧毁这个球形空间产生器。
输入
第一行是一个整数n(1<=N=10)。接下来的n+1行,每行有n个实数,表示球面上一点的n维坐标。每一个实数精确到小数点
后6位,且其绝对值都不超过20000。
输出
有且只有一行,依次给出球心的n维坐标(n个实数),两个实数之间用一个空格隔开。每个实数精确到小数点
后3位。数据保证有解。你的答案必须和标准输出一模一样才能够得分。
样例输入
0.0 0.0
-1.0 1.0
1.0 0.0
样例输出//大坑!!!这题在BZOJ上行末不能有空格,不然PE!丧病……上面要求的6位小数也是假的,要3位
提示
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}$
//博主是LaTeX成瘾者
解题思路
按照提示列出方程,发现二次项好烦啊!于是第1到第n个点的方程全部与第n+1个点的方程相减,二次项就消去了,然后就直接套高斯消元吧(个人觉得高斯消元解线性方程组就是加减消元的纯模拟,最多再加上了一个技巧——找当前列最大系数来消避免被卡精度)。这题不找当前列最大系数不会被卡精度,我没写……
源代码
#include<cmath>
#include<cstdio>
#include<algorithm>
using namespace std;
int n;
double m[][]={};
double x[]={};
double xy[][]={},sum[]={};//sum[i]为第i个点到原点距离的平方;
int main()
{
//freopen("bzoj_1013.in","r",stdin);
//freopen("bzoj_1013.out","w",stdout);//cogs的印记
scanf("%d",&n);
for(int i=;i<=n+;i++)
{
for(int j=;j<=n;j++)
{
scanf("%lf",&xy[i][j]);
sum[i]+=xy[i][j]*xy[i][j];
}
}
for(int i=;i<=n;i++)//消去二次项,形成m
{
for(int j=;j<=n;j++)
{
m[i][j]=*(xy[i][j]-xy[n+][j]);
}
m[i][n+]=sum[i]-sum[n+];
}
//高斯消元
for(int i=;i<=n;i++)
{
for(int j=i+;j<=n;j++)
{
if(abs(m[j][i])<1e-) continue;
double k=m[j][i]/m[i][i];
for(int h=i;h<=n+;h++)
{
m[j][h]-=m[i][h]*k;
}
}
}
for(int i=n;i;i--)
{
x[i]=m[i][n+]/m[i][i];
for(int j=i-;j;j--)
{
m[j][n+]-=x[i]*m[j][i];
m[j][i]=;
}
}
for(int i=;i<n;i++) printf("%.3lf ",x[i]);
printf("%.3lf",x[n]);
return ;
}
BZOJ 1013 cogs 1845 [JSOI2008]球形空间产生器sphere的更多相关文章
- 【BZOJ】1013: [JSOI2008]球形空间产生器sphere
[BZOJ]1013: [JSOI2008]球形空间产生器sphere 题意:给n+1个n维的点的坐标,要你求出一个到这n+1个点距离相等的点的坐标: 思路:高斯消元即第i个点和第i+1个点处理出一个 ...
- BZOJ 1013: [JSOI2008]球形空间产生器sphere 高斯消元
1013: [JSOI2008]球形空间产生器sphere Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/Judg ...
- bzoj 1013 [JSOI2008]球形空间产生器sphere(高斯消元)
1013: [JSOI2008]球形空间产生器sphere Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 3584 Solved: 1863[Subm ...
- BZOJ 1013 [JSOI2008]球形空间产生器sphere
1013: [JSOI2008]球形空间产生器sphere Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 3074 Solved: 1614[Subm ...
- bzoj千题计划104:bzoj1013: [JSOI2008]球形空间产生器sphere
http://www.lydsy.com/JudgeOnline/problem.php?id=1013 设球心(x1,x2,x3……) 已知点的坐标为t[i][j] 那么 对于每个i满足 Σ (t[ ...
- 【bzoj1013】[JSOI2008]球形空间产生器sphere
1013: [JSOI2008]球形空间产生器sphere Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 4530 Solved: 2364[Subm ...
- BZOJ1013 [JSOI2008]球形空间产生器sphere(高斯消元)
1013: [JSOI2008]球形空间产生器sphere Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 4846 Solved: 2525[Subm ...
- lydsy1013: [JSOI2008]球形空间产生器sphere 高斯消元
题链:http://www.lydsy.com/JudgeOnline/problem.php?id=1013 1013: [JSOI2008]球形空间产生器sphere 时间限制: 1 Sec 内 ...
- 线性代数(高斯消元):JSOI2008 球形空间产生器sphere
JSOI2008 球形空间产生器sphere [题目描述] 有一个球形空间产生器能够在n维空间中产生一个坚硬的球体.现在,你被困在了这个n维球体中,你只知道球面上n+1个点的坐标,你需要以最快的速度确 ...
随机推荐
- oc30--id
// // Person.h #import <Foundation/Foundation.h> @interface Person : NSObject - (void)sleep; @ ...
- linux驱动注册汇总
--- 01)TP file_operations: { 1. static struct file_operations tpd_fops = { // .owner = THIS_MODULE, ...
- poj 1840(五元三次方程组)
Description Consider equations having the following form: a1x1 3+ a2x2 3+ a3x3 3+ a4x4 3+ a5x5 3=0 T ...
- 第2章 安装Nodejs 2-2 Nodejs版本常识
- ROS-URDF-建立模型
前言:建立一个简单的urdf模型 详解请参看教程http://wiki.ros.org/urdf/Tutorials/Building%20a%20Visual%20Robot%20Model%20w ...
- POJ 3230 DP
f[i][j]=max(f[i][j],f[i-1][k]-a[k][j]+b[i][j]) i->第i天 j-–>到第j个城市 #include <cstdio> #incl ...
- MySQL学习笔记之右连接
MySQL的右连接 #右连接,以右表为基表 select course.stuid,course.stuname,sex,course,city from class1 right join cour ...
- 5.12redis
Window配置Redis环境和简单使用 一.关于Redis Redis是一个开源(BSD许可),内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理.它支持字符串.哈希表.列表.集合.有序 ...
- 1C课程笔记分享_StudyJams_2017
课程1C 概述 课程1C是创建一个生日贺卡应用的实践课程,所以本篇笔记分享主要记录个人的实践过程,此外分享一些比较零散的知识点. Drawable文件夹 Drawable文件夹是Android项目统一 ...
- Java code List Map, HashMap, JSON parser snippet
package com.newegg.ec.solr.eventsalestoreservice.tuple; import kafka.message.MessageAndMetadata; pub ...