SGU 208. Toral Tickets
208. Toral Tickets
time limit per test: 0.25 sec.
memory limit per test: 65536 KB
input: standard
output: standard
On the planet Eisiem passenger tickets for the new mean of transportation are planned to have the form of tores.
Each tore is made of a single rectangular black rubber sheet containing N × M squares. Several squares are marked with white, thus encoding the ticket's source and destination.
When the passenger buys the ticket, the ticket booking machine takes the rubber sheet, marks some squares to identify the route of the passenger, and then provides it to the passenger. The passenger next must glue the ticket.
The ticket must be clued the following way. First two its sides of greater length are glued together, forming a cylinder. Next cylinder base circles, each of which has the length equal to the length of the short side of the original rubber sheet, are glued together. They must be glued in such a way, that the cells, sides of which are glued, first belonged to the same row of the sheet. Note that the inner and the outer part of the sheet can be distinguished.
The resulting tore is the valid ticket.
Note that if the original sheet is square, there are two topologically different ways to make a tore out of a rubber sheet.
Ticket material is so perfect and gluing quality is so fine, that no one is able to find the seam, and this leads to some problems. First, the same tore can be obtained using different sheets. More of that, the same sheet can lead to tores that look a bit different.
Now the transport companies of Eisiem wonder, how many different routes they can organize, so that the following conditions are satisfied:
tickets for different routes are represented by different tores;
if some rubber sheet was marked to make the tore for some route, it cannot be used to make the tore for another route.
Help them to calculate the number of routes they can organize.
Input
The first line of the input file contains N and M (1 ≤ N, M ≤ 20).
Output
Output the number of routes Eisiem transport companies can organize.
Sample test(s)
Input
Test #1
2 2
Test #2
2 3
Output
Test #1
6
Test #2
13
题意
给你N和M,对于一个N*M的单面方格纸你可以对它的每个个格子黑白染色,然后把方格纸的长边卷起来,卷成一个圆柱体,然后再把两个短边形成的圆也接起来,形成一个游泳圈的形状(我们染的色只在游泳圈的外表面)。如果对于两种黑白染色方案,通过卷成这样的游泳圈后,是一样的,则这两种方案也是一样的。给定N,M<=20 ,求染色方案总数.
很明显的polya计数,不会的话下面列出了一些参考:
- 刘老师的黑书
- http://wenku.baidu.com/view/bf92a95f804d2b160b4ec0be.html
- http://zhangchi.weebly.com/uploads/8/7/5/5/8755757/polya.pdf
需要高精度。
#include <bits/stdc++.h>
#define rep(_i, _j) for(int _i = 1; _i <= _j; ++_i)
const int inf = 0x3f3f3f3f;
typedef long long LL;
typedef double DB;
using namespace std;
const int maxm = 20 + 2;
const int maxn = 400 + 20;
const int maxlen = 140 + 10;
struct big_num {
	int d[maxlen], len;
	big_num() {
		memset(d, 0, sizeof d);
		len = 1;
	}
	inline int & operator [] (int index) {
		return d[index];
	}
	friend big_num operator + (big_num lhs, big_num rhs) {
		big_num ret;
		ret.len = max(lhs.len, rhs.len);
		for(int i = 1; i <= ret.len; ++i) {
			ret[i] += lhs[i] + rhs[i];
			if(ret[i] > 9) {
				ret[i] %= 10, ret[i + 1] += 1;
			}
		}
		if(ret[ret.len + 1] > 0) ++ret.len;
		return ret;
	}
	friend big_num operator / (big_num lhs, int rhs) {
		big_num ret;
		int remain = 0;
		for(int i = lhs.len; 0 < i; --i) {
			remain = remain * 10 + lhs[i];
			if(remain >= rhs) {
				ret[i] = remain / rhs;
				remain %= rhs;
			}
		}
		for(ret.len = maxlen - 1; 1 < ret.len; --ret.len) {
			if(ret[ret.len] > 0) break;
		}
		return ret;
	}
	void print() {
		for(int i = len; 0 < i; --i)
			printf("%d", d[i]);
	}
};
big_num pow2[maxn], ans;
int n, m;
int cache[maxn], hash[maxn];
int Ranma[maxm][maxm];
void right_shift() {
	for(register int i = 0, t; i < n; ++i) {
		t = Ranma[i][m - 1];
		for(int j = m - 1; 0 < j; --j) {
			Ranma[i][j] = Ranma[i][j - 1];
		}
		Ranma[i][0] = t;
	}
}
void down_shift() {
	for(register int i = 0, t; i < m; ++i) {
		t = Ranma[n - 1][i];
		for(int j = n - 1; 0 < j; --j) {
			Ranma[j][i] = Ranma[j - 1][i];
		}
		Ranma[0][i] = t;
	}
}
void rot() {
	int tmp[maxm][maxm];
	memcpy(tmp, Ranma, sizeof Ranma);
	for(int i = 0; i < m; ++i) {
		for(int j = n - 1; -1 < j; --j) {
			Ranma[i][n - 1 - j] = tmp[j][i];
		}
	}
	swap(n, m);
}
int calc() {
	int ret = 0;
	memset(hash, 0, sizeof hash);
	for(int i = 0; i < n; ++i) {
		for(int j = 0; j < m; ++j) {
			cache[i * m + j] = Ranma[i][j];
		}
	}
	for(register int i = 0, uper = n * m, now; i < uper; ++i) {
		if(!hash[i]) {
			++ret;
			for(now = i; !hash[now]; hash[now] = 1, now = cache[now]);
		}
	}
	return ret;
}
void print() {
	for(int i = 0; i < n; ++i) {
		for(int j = 0; j < m; ++j) {
			printf("%d ", Ranma[i][j]);
		}
		puts("");
	}
	puts("");
}
int main() {
#ifndef ONLINE_JUDGE
	freopen("208.in", "r", stdin); freopen("208.out", "w", stdout);
#endif
	pow2[0].d[1] = 1;
	for(int i = 1; i < maxn; ++i)
		pow2[i] = pow2[i - 1] + pow2[i - 1];
	scanf("%d%d", &n, &m);
	for(int i = 0; i < n; ++i) {
		for(int j = 0; j < m; ++j) {
			Ranma[i][j] = i * m + j;
		}
	}
	for(int i = 0; i < n; ++i) {
		for(int j = 0; j < m; ++j) {
			ans = ans + pow2[calc()];
			rot();
			if(n == m) ans = ans + pow2[calc()];
			rot();
			ans = ans + pow2[calc()];
			rot();
			if(n == m) ans = ans + pow2[calc()];
			rot();
			right_shift();
		}
		down_shift();
	}
	ans = ans / (n * m * 2 * (n == m ? 2 : 1));
	ans.print();
	puts("");
	return 0;
}
SGU 208. Toral Tickets的更多相关文章
- 【SGU 390】Tickets (数位DP)
		Tickets Description Conductor is quite a boring profession, as all you have to do is just to sell ... 
- sgu208:Toral Tickets(Pólya定理)
		题意简述:给你N和M,对于一个N∗M的单面方格纸你能够对它的每 个个格子黑白染色.然后把方格纸的长边卷起来,卷成一个圆柱体,然后再把 两个短边形成的圆也接起来.形成一个游泳圈的形状(我们染的色仅仅在游 ... 
- POJ2828 Buy Tickets[树状数组第k小值 倒序]
		Buy Tickets Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 19012 Accepted: 9442 Desc ... 
- ACM:   FZU 2112 Tickets - 欧拉回路 - 并查集
		FZU 2112 Tickets Time Limit:3000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u P ... 
- Tickets——H
		H. Tickets Jesus, what a great movie! Thousands of people are rushing to the cinema. However, this i ... 
- POJ 2828 Buy Tickets(线段树 树状数组/单点更新)
		题目链接: 传送门 Buy Tickets Time Limit: 4000MS Memory Limit: 65536K Description Railway tickets were d ... 
- SGU 495. Kids and Prizes
		水概率....SGU里难得的水题.... 495. Kids and Prizes Time limit per test: 0.5 second(s)Memory limit: 262144 kil ... 
- ACM:   SGU 101 Domino- 欧拉回路-并查集
		sgu 101 - Domino Time Limit:250MS Memory Limit:4096KB 64bit IO Format:%I64d & %I64u Desc ... 
- 【SGU】495. Kids and Prizes
		http://acm.sgu.ru/problem.php?contest=0&problem=495 题意:N个箱子M个人,初始N个箱子都有一个礼物,M个人依次等概率取一个箱子,如果有礼物则 ... 
随机推荐
- django2.0 uwsgi nginx
			[TOC]# 1.安装pip```sudo apt-get updatesudo apt-get install python-pip```# 2.使用pip 安装virtualenv 和 virtu ... 
- 图像处理之均值滤波介绍及C算法实现
			1 均值滤波介绍 滤波是滤波是将信号中特定波段频率滤除的操作,是从含有干扰的接收信号中提取有用信号的一种技术. 均值滤波是典型的线性滤波算法,它是指在图像上对目标像素给一个模板,该模板包括了其周围的临 ... 
- Linux下的tar压缩解压缩命令详解(转)
			tar -c: 建立压缩档案-x:解压-t:查看内容-r:向压缩归档文件末尾追加文件-u:更新原压缩包中的文件 这五个是独立的命令,压缩解压都要用到其中一个,可以和别的命令连用但只能用其中一个.下面的 ... 
- springMVC的controller返回值
			1.可以返回ModelAndView 2.可以返回一个String字符串:即一个jsp页面的逻辑视图名,这个在springMVC.xml中可以配置此页面逻辑视图的前缀和后缀 3.可以返回void类型: ... 
- LINUX安全加固操作
			1.禁止Ctrl-Alt-Delete组合键重启系统 vi /etc/inittab #ca::ctrlaltdel:/sbin/shutdown -t3 -r now 如果还存在下面的文件,则需要注 ... 
- 管理lnmp常用命令,lnmp重启,start|stop|reload|restart等命令
			LNMP状态管理命令: LNMP状态管理: /root/lnmp {start|stop|reload|restart|kill|status}Nginx状态管理:/etc/init.d/nginx ... 
- 「Django」rest_framework学习系列-序列化
			序列化方式一 :在业务类里序列化数据库数据 class RolesView(APIView): def get(self,request,*args,**kwargs): roles = models ... 
- 效应量Effect Size
			sklearn实战-乳腺癌细胞数据挖掘(博主亲自录制视频教程) https://study.163.com/course/introduction.htm?courseId=1005269003&am ... 
- ubuntu环境下添加中文输入法
			1.下载软件包 打开终端,输入命令 sudo apt-get install fcitx-table-wbpy 2.打开 system settings-> language support-& ... 
- Android 加载网络图片设置到ImageView
			下载图片后显示在ImageView中 //1.定义全局变量 private Handler handler; private String image_url; private Bitmap bitm ... 
