高斯消元,今天数学死了无数次……

#include <cstdio>
#include <cstring>
#include <cmath>
#include <iostream>
#include <algorithm>
#define LL __int64
const int maxn=55;
#define mod 200000000000000003LL //不能用const来定义。。,不知道为什么,需要是素数
#define diff 100000000000000000LL //偏移量,使得数都是整数,方便移位乘法
using namespace std;
LL x[maxn], g[maxn][maxn], a[maxn][maxn], b[maxn][maxn];
int n;
LL Mod(LL x)//加法取模,防止超__int64
{
if(x>=mod)
return x-mod;
return x;
}
LL mul(LL a,LL b)//乘法,用移位乘法,同样防止超__int64
{
LL s;
for(s=0;b;b>>=1)
{
if(b&1)
s=Mod(s+a);
a=Mod(a+a);
}
return s;
}
void gcd(LL a,LL b,LL d,LL &x,LL &y)//拓展的欧几里德定理,求ax+by=gcd(a,b)的一个解
{
if(!b){d=a;x=1;y=0;}
else{gcd(b,a%b,d,y,x);y-=x*(a/b);}
}
LL inv(LL a,LL n)//求逆,用于除法
{
LL x,y,d;
gcd(a,n,d,x,y);
return (x%n+n)%n;
}
void Gauss()//高斯消元
{
int i,j,k;
LL v,tmp;
for(i=0;i<n;i++)
{
for(j=i;j<n;j++)
{
if(g[j][i])
break;
}
if(i!=j)
{
for(k=i;k<=n;k++)
swap(g[i][k],g[j][k]);
}
v=inv(g[i][i],mod);
for(j=i+1;j<n;j++)
{
if(g[j][i])
{
tmp=mul(g[j][i],v);//相当于g[j][i]/g[i][i]%mod;
for(k=i;k<=n;k++)
{
g[j][k]-=mul(tmp,g[i][k]);
g[j][k]=(g[j][k]%mod+mod)%mod;
}
}
}
}
//求出所以的解,存入x数组中
for(i=n-1;i>=0;i--)
{
tmp=0;
for(j=i+1;j<n;j++)
{
tmp+=mul(x[j],g[i][j]);
if(tmp>=mod)
tmp-=mod;
}
tmp=g[i][n]-tmp;
tmp=(tmp%mod+mod)%mod;
x[i]=mul(tmp,inv(g[i][i],mod));
}
}
int main()
{
int T,tt=0;
int i,j;
LL tmp;
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
memset(g,0,sizeof(g));
memset(b,0,sizeof(b));
for(i=0;i<=n;i++)
{
for(j=0;j<n;j++)
{
scanf("%I64d",&a[i][j]);
a[i][j]+=diff;//偏移diff
b[i][n]+=mul(a[i][j],a[i][j]);
if (b[i][n]>=mod)
b[i][n]-=mod;
}
}
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
tmp=a[i+1][j]-a[i][j];
tmp=(tmp%mod+mod)%mod;
g[i][j]=mul(tmp,2);
}
g[i][n]=b[i+1][n]-b[i][n];
g[i][n]=(g[i][n]%mod+mod)%mod;
}
Gauss();
printf("Case %d:\n",++tt);
printf("%I64d",x[0]-diff);//减去先前偏移的值。
for (i=1;i<n;i++)
printf(" %I64d",x[i]-diff);
printf("\n");
}
return 0;
}
/*
由题意,列方程组∑(xj-aij)^2=R^2(0<=j<n),共n+1个方程。
存在未知数R,以及二次方,需要降次。逐个与上方方程做差,得到n元一次方程组,共n个方程。
剩下套高斯消元的模板就OK了。
不过这题有几点需要注意:
1.未知数是xi<=1e17,所以无法直接乘除。又∑ai*xi=an和∑ai*xi=an(mod n)(0<=i<=n,xi<n)的解相同
(乘法和加法取余处理下酒能证明)。所以可以%mod来解决。
2.由于需要求逆,所以mod为素数2e17+3。又正常乘法会超过__int64,所以需要用移位乘法。
3.为简单化移位,需要乘数,所以需要添加偏移量diff,根据数学运算可知,只要最后结果减去偏移量即可。
*/

HDU 3571 N-dimensional Sphere的更多相关文章

  1. HDU 3571 N-dimensional Sphere( 高斯消元+ 同余 )

    N-dimensional Sphere Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Oth ...

  2. HDU 3571 N-dimensional Sphere(高斯消元 数论题)

    这道题算是比较综合的了,要用到扩展欧几里得,乘法二分,高斯消元. 看了题解才做出来orz 基本思路是这样,建一个n*(n-1)的行列式,然后高斯消元. 关键就是在建行列式时会暴long long,所以 ...

  3. HDU.3571.N-dimensional Sphere(高斯消元 模线性方程组)

    题目链接 高斯消元详解 /* $Description$ 在n维空间中给定n+1个点,求一个点使得这个点到所有点的距离都为R(R不给出).点的任一坐标|xi|<=1e17. $Solution$ ...

  4. HDU题解索引

    HDU 1000 A + B Problem  I/O HDU 1001 Sum Problem  数学 HDU 1002 A + B Problem II  高精度加法 HDU 1003 Maxsu ...

  5. 高斯消元 分析 && 模板 (转载)

    转载自:http://hi.baidu.com/czyuan_acm/item/dce4e6f8a8c45f13d7ff8cda czyuan 先上模板: /* 用于求整数解得方程组. */ #inc ...

  6. 可用类型的几何对象esriGeometryType Constants

    The available kinds of geometry objects. Constant Value Description esriGeometryNull 0 A geometry of ...

  7. hdu 5727 Necklace dfs+二分图匹配

    Necklace/center> 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5727 Description SJX has 2*N mag ...

  8. HDU 5976 Detachment 打表找规律

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5976 Detachment Time Limit: 4000/2000 MS (Java/Other ...

  9. HDU 5976 Detachment(拆分)

    HDU 5976 Detachment(拆分) 00 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)   Problem D ...

随机推荐

  1. Hibernate的使用梳理

    Hibernate创建步骤 (五大核心接口:Configuration/SessionFactory/Session/Transaction/Query) 1.新建java工程,导入需要的jar包. ...

  2. Visual Studio之Nuget

    一.NuGet是什么? NuGet是一个为大家所熟知的Visual Studio扩展,通过这个扩展,开发人员可以非常方便地在Visual Studio中安装或更新项目中所需要的第三方组件,同时也可以通 ...

  3. .Net平台-MVP模式再探(二)

    PS:     本文与  上一遍文章  没有什么必然的联系,可以说是对于MVP的一定的加深,或许在理解上比上一篇多有点难度. 正文   一.简单讲讲MVP是什么玩意儿 如果从层次关系来讲,MVP属于P ...

  4. fatal error LNK1123: failure during conversion to COFF: file invalid or corr

    新装VS2010出现标题的错误,使用了下面的方法,不行 这个是由于日志文件引起的,可以将 项目\属性\配置属性\清单工具\输入和输出\嵌入清单:原来是"是",改成"否&q ...

  5. 新视野OJ 2705 [SDOI2012]Longge的问题 (数论)

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2705 题解:求 sigma(gcd(i,n), 1<=i<=n<2^32) ...

  6. Apache 开启 Https

    1. 准备所需工具: 1) apache httpd2.4 浏览 2) Win32 OpenSSL v1.0.2d 浏览 2. 安装 2.1 安装Apache2.4服务 php环境搭建 浏览 2.2 ...

  7. VS中,NUnit适合测试者尽心开发自动化测试,而Unit适合开发者开发单元测试。

    1.整合Visual Studio和NUnit 在Visual Studio 2010中,通过安装NUnit插件,可以不使用外部客户端,直接运行测试. 当然,貌似在最新版本的VS2012中,安装过NU ...

  8. [C++]Saving the Universe——Google Code Jam Qualification Round 2008

    Google Code Jam 2008 资格赛的第一题:Saving the Universe. 问题描述如下: Problem The urban legend goes that if you ...

  9. IOS 特定于设备的开发:Core Motion基础

    Core Motion框架集中了运动数据处理.该框架是在IOS 4 SDK中引入的,用于取代accelerometer加速计访问.它提供了对3个关键的机载传感器的集中式监测.这些传感器有陀螺仪.磁力计 ...

  10. 成都Uber优步司机快速注册攻略(外地车牌也可加入,不用现场培训)

    我加入Uber司机有一段时间了,有一些经验和感想分享给大家,让大家少走些弯路.目前加入优步不收取任何费用,不需要抢单,时间安排自由灵活,使用便捷,深受大众喜爱. 加入人民优步拼车条件:购买运行5年之内 ...