首先,中心点是能够直接算出来的

把全部的坐标相加再除n就能够

然后枚举一个不靠近中心的点,枚举它绕中心点旋转的角度。仅仅要枚举50次就能够了

计算出当前枚举的的角度能否形成一个置换群

计算循环节,再用polya定理算个数

#pragma comment(linker, "/STACK:102400000,102400000")
#include<iostream>
#include<vector>
#include<algorithm>
#include<cstdio>
#include<queue>
#include<stack>
#include<string>
#include<map>
#include<set>
#include<cmath>
#include<cassert>
#include<cstring>
#include<iomanip>
using namespace std;
#ifdef _WIN32
#define i64 __int64
#define out64 "%I64d\n"
#define in64 "%I64d"
#else
#define i64 long long
#define out64 "%lld\n"
#define in64 "%lld"
#endif
/************ for topcoder by zz1215 *******************/
#define foreach(c,itr) for(__typeof((c).begin()) itr=(c).begin();itr!=(c).end();itr++)
#define FOR(i,a,b) for( int i = (a) ; i <= (b) ; i ++)
#define FF(i,a) for( int i = 0 ; i < (a) ; i ++)
#define FFD(i,a,b) for( int i = (a) ; i >= (b) ; i --)
#define S64(a) scanf(in64,&a)
#define SS(a) scanf("%d",&a)
#define LL(a) ((a)<<1)
#define RR(a) (((a)<<1)+1)
#define pb push_back
#define pf push_front
#define X first
#define Y second
#define CL(Q) while(!Q.empty())Q.pop()
#define MM(name,what) memset(name,what,sizeof(name))
#define MC(a,b) memcpy(a,b,sizeof(b))
#define MAX(a,b) ((a)>(b)?(a):(b))
#define MIN(a,b) ((a)<(b)?(a):(b))
#define read freopen("out.txt","r",stdin)
#define write freopen("out2.txt","w",stdout) const int inf = 0x3f3f3f3f;
const i64 inf64 = 0x3f3f3f3f3f3f3f3fLL;
const double oo = 10e9;
const double eps = 10e-6;
const double pi = acos(-1.0);
const int maxn = 55;
const int mod = 1000000007; int n, m, c;
int nx[maxn];
int ny[maxn];
double cita[maxn];
double r[maxn];
double cx, cy;
int a[maxn];
int b[maxn];
int edge[maxn][maxn]; i64 gcd(i64 _a, i64 _b)
{
if (!_a || !_b)
{
return max(_a, _b);
}
i64 _t;
while ((_t = _a % _b))
{
_a = _b;
_b = _t;
}
return _b;
} i64 ext_gcd(i64 _a, i64 _b, i64 &_x, i64 &_y)
{
if (!_b)
{
_x = 1;
_y = 0;
return _a;
}
i64 _d = ext_gcd(_b, _a % _b, _x, _y);
i64 _t = _x;
_x = _y;
_y = _t - _a / _b * _y;
return _d;
} i64 invmod(i64 _a, i64 _p)
{
i64 _ans, _y;
ext_gcd(_a, _p, _ans, _y);
_ans < 0 ? _ans += _p : 0;
return _ans;
} double gao(double x,double y){
if (abs(x) < eps){
if (y>0){
return pi / 2.0;
}
else{
return pi + pi / 2.0;
}
}
else if (x >= 0 && y >= 0){
return atan(y / x);
}
else if (x <= 0 && y >= 0){
x = -x;
return pi - atan(y / x);
}
else if (x <= 0 && y <= 0){
x = -x;
y = -y;
return pi + atan(y / x);
}
else {
y = -y;
return 2 * pi - atan(y / x);
}
} int find(double tcita,double tr){
if (tcita > 2 * pi){
tcita -= 2 * pi;
}
double tx = cx + tr*cos(tcita);
double ty = cy + tr*sin(tcita);
for (int i = 1; i <= n; i++){
if (abs(tx - nx[i]) < eps && abs(ty-ny[i]) < eps){
return i;
}
}
return -1;
} bool isint(double temp){
int t2 = temp;
temp -= t2;
if (temp < eps) {
return true;
}
else{
return false;
}
} bool can(){
int now, to;
for (int x = 1; x <= n; x++){
for (int y = 1; y <= n; y++){
now = b[x];
to = b[y];
if (edge[x][y] != edge[now][to]){
return false;
}
}
}
return true;
} bool vis[maxn]; int count(){
MM(vis, 0);
int re = 0;
int now, to;
for (int x = 1; x <= n; x++){
if (!vis[x]){
now = x;
vis[now] = true;
re++;
while (true){
to = b[now];
if (vis[to]){
break;
}
else{
vis[to] = true;
now = to;
}
}
}
}
return re;
} i64 pow_mod(int x,int temp){
i64 re = 1;
for (int i = 1; i <= temp; i++){
re *= x;
re %= mod;
}
return re;
} i64 start(){
cx = 0.0;
cy = 0.0;
for (int i = 1; i <= n; i++){
cx += nx[i];
cy += ny[i];
}
cx /= n;
cy /= n;
double tx, ty;
for (int i = 1; i <= n; i++){
tx = nx[i] - cx;
ty = ny[i] - cy;
r[i] = sqrt(tx*tx + ty*ty);
cita[i] = gao(tx, ty);
}
double spin;
i64 ans = 0;
i64 sg =0;
int id;
for (int i = 1; i <= n; i++){
if (abs(cx - nx[i]) > eps || abs(cy - ny[i]) > eps){
id = i;
break;
}
}
for (int i = 1; i <= n; i++){
spin = cita[i] - cita[id];
if (abs(r[i] - r[id]) < eps){
bool no = false;
for (int x = 1; x <= n; x++){
a[x] = find(cita[x] + spin, r[x]);
if (a[x] == -1){
no = true;
break;
}
b[a[x]] = x;
}
if (no) continue;
if (can()){
sg++;
ans += pow_mod(c, count());
ans %= mod;
}
}
}
ans *= invmod(sg, mod);
ans %= mod;
return ans;
} int main(){
int T;
cin >> T;
while (T--){
cin >> n >> m >> c;
for (int i = 1; i <= n; i++){
cin >> nx[i] >> ny[i];
}
for (int i = 0; i <= n; i++){
for (int j = 0; j <= n; j++){
edge[i][j] = 0;
}
}
int now, to;
for (int i = 1; i <= m; i++){
cin >> now >> to;
edge[now][to] = edge[to][now] = 1;
}
if (n == 1){
cout << c << endl;
continue;
}
i64 ans = start();
cout << ans << endl;
}
return 0;
}

hdu 5080 2014ACM/ICPC鞍山K题 polya计数的更多相关文章

  1. hdu 5122(2014ACM/ICPC亚洲区北京站) K题 K.Bro Sorting

    传送门 对于错想成lis的解法,提供一组反例 1 3 4 2 5同时对于这次案例也可以观察出解法:对于每一个数,如果存在比它小的数在它后面,它势必需要移动,因为只能小的数无法向右移动,而且每一次移动都 ...

  2. HDU 5115 (2014ACM/ICPC亚洲区北京站) D题(Dire Wolf)

    题目传送门 设dp[i][j]为杀掉区间i到j之间的狼需要付出的最小代价,那么dp[i][j]=min{dp[i][k-1]+dp[k+1][j]+a[k]+b[i-1]+b[j+1]} Java代码 ...

  3. 2017 ACM/ICPC 沈阳 K题 Rabbits

    Here N (N ≥ 3) rabbits are playing by the river. They are playing on a number line, each occupying a ...

  4. hdu5080:几何+polya计数(鞍山区域赛K题)

    /* 鞍山区域赛的K题..当时比赛都没来得及看(反正看了也不会) 学了polya定理之后就赶紧跑来补这个题.. 由于几何比较烂写了又丑又长的代码,还debug了很久.. 比较感动的是竟然1Y了.. * ...

  5. HDU 5127.Dogs' Candies-STL(vector)神奇的题,set过不了 (2014ACM/ICPC亚洲区广州站-重现赛(感谢华工和北大))

    周六周末组队训练赛. Dogs' Candies Time Limit: 30000/30000 MS (Java/Others)    Memory Limit: 512000/512000 K ( ...

  6. HDU 4041 Eliminate Witches! (模拟题 ACM ICPC 2011亚洲北京赛区网络赛)

    HDU 4041 Eliminate Witches! (模拟题 ACM ICPC 2011 亚洲北京赛区网络赛题目) Eliminate Witches! Time Limit: 2000/1000 ...

  7. HDU 5131.Song Jiang's rank list (2014ACM/ICPC亚洲区广州站-重现赛)

    Song Jiang's rank list Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 512000/512000 K (Java ...

  8. HDU 5135.Little Zu Chongzhi's Triangles-字符串 (2014ACM/ICPC亚洲区广州站-重现赛)

    Little Zu Chongzhi's Triangles Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 512000/512000 ...

  9. hdu 5868 Polya计数

    Different Circle Permutation Time Limit: 3000/1500 MS (Java/Others)    Memory Limit: 262144/262144 K ...

随机推荐

  1. jQuery mouseover,mouseout事件多次执行的问题处理

    控制鼠标移上移下事件,在使用Jquery 的mouseover,mouseout事件时,元素内部含有其它元素,会造成该事件多次的触发的情况. 问题解析 在用到mouseover和mouseout事件来 ...

  2. Linux内核如何启动并装载一个可执行程序

    2016-04-07 张超<Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000#/info 一.理解编译链接的 ...

  3. 从客户端检测到有潜在危险的Request.Form值

    1.带有html标记内容提交(使用web编辑器): js: <script type="text/javascript"> //简单模式 var editor; Kin ...

  4. .net抓取网页数据

    1.想通过代码获得某个页面的数据,首先根据右键查看页面源代码,通过分析.再通过下面代码,修改,一步步查找出所需内容,存入数据库. //根据Url地址得到网页的html源码 private string ...

  5. nginx 配置文件解析(一)

    nginx.conf user nginx; # nginx服务的运行用户 worker_processes ; # 启动进程数,通常设置成和CPU的数量相等 error_log /var/log/n ...

  6. 在.NET MVC下不用iframe实现局部加载html

    最近在做个后台系统,之前都是用iframe来实现加载内容,左侧菜单不刷新.但一直不喜欢这种方法,有许多弊端.今天自己在网上查找了一番后找到了比较好的替代方案: 一.利用html的锚点标记来实现无刷新页 ...

  7. python之6-5偏函数

    functools.partial 偏函数的作用是简化操作,简化什么操作呢?就是当我们有一个已知函数A,且这个函数包含有某个或多个参数A1,通过固定这个参数A1,我们可以自己编写一个新函数B,来减少代 ...

  8. 未能在全局命名空间中找到类型或命名空间名称“Wuqi”

    下载了AspNetPager控件用以进行分页操作,在项目中放入控件后,运行报错:未能在全局命名空间中找到类型或命名空间名称“Wuqi” . 解决办法:在项目下拉框“引用“中添加AspNetPager引 ...

  9. [工具] 解决sublime text运行javascript console无输出问题

    1.使用nodeJS在sublime text 运行javascript 下载安装nodeJS 在sublime text新建build system:tools->build system-& ...

  10. 为什么memset的第二个参数不把int替换成char

    memset是一个经常被用来初始化数组的函数,其定义如下: 1 void * memset ( void * ptr, int value, size_t num ); 它的效果大致是把以ptr为起始 ...