zoukankan      html  css  js  c++  java
  • bzoj 1013: [JSOI2008]球形空间产生器sphere

    Description

      有一个球形空间产生器能够在n维空间中产生一个坚硬的球体。现在,你被困在了这个n维球体中,你只知道球
    面上n+1个点的坐标,你需要以最快的速度确定这个n维球体的球心坐标,以便于摧毁这个球形空间产生器。

    solution

    正解:高斯消元
    比较简单,我们用 (dis[1]=dis[i]),列出n个方程,然后高斯消元即可

    #include <algorithm>
    #include <iostream>
    #include <cstdlib>
    #include <cstring>
    #include <cstdio>
    #include <cmath>
    #define RG register
    #define il inline
    #define iter iterator
    #define Max(a,b) ((a)>(b)?(a):(b))
    #define Min(a,b) ((a)<(b)?(a):(b))
    using namespace std;
    typedef long long ll;
    const double eps=1e-7;
    double a[15][15],x[15][15];int n;
    void solve(){
    	double tmp;
    	for(int l=1;l<=n;l++){
    		int maxid=l;
    		for(int i=l+1;i<=n;i++)
    			if(fabs(a[i][l])>fabs(a[maxid][l]))maxid=i;
    		if(maxid!=l)swap(a[l],a[maxid]);
    		for(int i=l+1;i<=n;i++){
    			if(fabs(a[i][l])<eps)continue;
    			tmp=a[l][l]/a[i][l];
    			for(int j=l;j<=n+1;j++)
    				a[i][j]=a[l][j]-tmp*a[i][j];
    		}
    	}
    	for(int i=n;i>=1;i--){
    		for(int j=i+1;j<=n;j++)
    			a[i][n+1]-=a[i][j]*a[j][n+1];
    		if(fabs(a[i][i])>eps)a[i][n+1]/=a[i][i];
    	}
    	printf("%.3lf",fabs(a[1][n+1]));
    	for(int i=2;i<=n;i++)printf(" %.3lf",fabs(a[i][n+1]));
    }
    void work()
    {
    	cin>>n;
    	for(int i=1;i<=n+1;i++)
    		for(int j=1;j<=n;j++)
    			scanf("%lf",&x[i][j]);
    	for(int i=2;i<=n+1;i++){
    		for(int j=1;j<=n;j++)
    			a[i-1][j]+=2*(x[i][j]-x[1][j]),
    				a[i-1][n+1]+=x[i][j]*x[i][j]-x[1][j]*x[1][j];
    	}
    	solve();
    }
    
    int main()
    {
    	freopen("pp.in","r",stdin);
    	freopen("pp.out","w",stdout);
    	work();
    	return 0;
    }
    
    
  • 相关阅读:
    Vue项目中跨域问题解决
    子网掩码
    C++的const类成员函数
    在python3中使用urllib.request编写简单的网络爬虫
    Linux 重定向输出到多个文件中
    背包问题
    hdu-1272 小希的迷宫
    SQLAlchemy 几种查询方式总结
    pycharm快捷键、常用设置、配置管理
    python3判断字典、列表、元组为空以及字典是否存在某个key的方法
  • 原文地址:https://www.cnblogs.com/Yuzao/p/8038924.html
Copyright © 2011-2022 走看看