ZOJ 3817 Chinese Knot
题意:给定4个长度为N的字符串( N <= 100000),然后构成一个“中国结”,给定目标串,问能否从某个节点出发走一遍得到目标串,其中不能连续通过3个中心节点,也就是从字符串一个端点转移到其他端点后必须沿着这条字符串走。
分析:对4个字符串正反两面和目标串建立相应hash函数,然后暴力枚举每一个位置出发就可以了,可以有正反两个方向的走法。中间注意一下细节差不多就可以了。

代码:
#include <bits/stdc++.h>
#pragma comment(linker, "/STACK:102400000,102400000")
#define in freopen("F:\\rootial\\data\\data.txt", "r", stdin);
#define bug(x) printf("Line %d: >>>>>>\n", (x));
#define pb push_back
#define mp make_pair using namespace std;
typedef long long LL;
typedef unsigned long long ULL;
typedef pair<int, int> PII;
typedef vector<pair<int, int > > VII; const ULL seed = ; const int maxn = + ;
char s[][maxn], ta[maxn];
ULL hh[][maxn], tt[maxn], HH[maxn];
void pre()
{
tt[] = ;
for(int i = ; i < maxn; i++)
tt[i] = tt[i-]*seed;
}
int n, m;
VII ans;
bool dfs(int x, int pos, int dir, int len)
{
if(len == )
return true;
int len1 = n-pos+;
int mlen = min(len, len1);
int ok = ;
if(hh[x<<|dir][pos]-hh[x<<|dir][pos+mlen]*tt[mlen] == HH[m-len+]-HH[m-len+mlen+]*tt[mlen])
{
ok = ;
ans.pb(mp(x*n+(dir ? n+-pos : pos), dir));
len -= mlen;
if(len == )
return true;
for(int k = ; k < ; k++)
for(int j = ; j < ; j++)
{
if(k == x && (j^) == dir)
continue;
if(dfs(k, , j, len))
return true;
}
}
if(ok)
ans.pop_back();
return false;
}
int main()
{ pre();
int T;
for(int t(scanf("%d", &T)); t <= T; t++)
{
scanf("%d%d", &n, &m);
for(int i = ; i < ; i++)
scanf("%s", s[i]+);
scanf("%s", ta+);
for(int i = ; i < ; i++)
hh[i][n+] = ;
HH[m+] = ;
for(int i = ; i < ; i++)
{
for(int j = n; j >= ; j--)
{
hh[i<<][j] = hh[i<<][j+]*seed+(s[i][j]-'a');
hh[i<<|][j] = hh[i<<|][j+]*seed+(s[i][n+-j]-'a');
}
}
for(int i = m; i >= ; i--)
{
HH[i] = HH[i+]*seed+(ta[i]-'a');
}
int ok = ;
for(int k = ; k < ; k++)
{
for(int pos = ; pos <= n; pos++)
{
for(int j = ; j < ; j++)
{
ok = ;
ans.clear();
if(dfs(k, pos, j, m))
{
ok = ;
break;
}
if(ok)
break;
}
if(ok)
break;
}
if(ok)
{
break;
}
}
int ll = ;
if(ok)
{
for(int i = ; i < ans.size(); i++)
{
PII x = ans[i];
int st = x.first;
int dir = x.second;
int k = (st-)/n+; if(dir == )
{
for(int j = st; j <= k*n && ll < m; j++, ll++)
{
if(ll)
putchar(' ');
printf("%d", j);
}
}
else
{
for(int j = st; j > (k-)*n && ll < m; j--, ll++)
{
if(ll)
putchar(' ');
printf("%d", j);
}
}
}
cout<<endl;
}
else
{
puts("No solution!");
}
}
return ;
}
ZOJ 3817 Chinese Knot的更多相关文章
- 数学+高精度 ZOJ 2313 Chinese Girls' Amusement
题目传送门 /* 杭电一题(ACM_steps 2.2.4)的升级版,使用到高精度: 这次不是简单的猜出来的了,求的是GCD (n, k) == 1 最大的k(1, n/2): 1. 若n是奇数,则k ...
- zoj 2313 Chinese Girls' Amusement 解题报告
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1313 题目意思:有 N 个人(编号依次为1~N)围成一个圆圈,要求求 ...
- ASC #1
开始套题训练,第一套ASC题目,记住不放过每一题,多独立思考. Problem A ZOJ 2313 Chinese Girls' Amusement 循环节 题意:给定n,为圆环长度,求k < ...
- 使用MySQL数据库将汉字转换成拼音的一个C语言小程序
环境: mysql:mysql-5.1.65 centos:centos 6.5 编译命令: gcc -o chinesetopinyin chinesetopinyin.c -L/usr/lib/m ...
- A - Chinese Girls' Amusement ZOJ - 2313(大数)
You must have heard that the Chinese culture is quite different from that of Europe or Russia. So so ...
- ZOJ 3817Chinese Knot(The 2014 ACM-ICPC Asia Mudanjiang Regional First Round)
思路: 将4个串每个串都反向这样得到新的四个串一共8个串,对于母串每个位置检测这个串能不能放进去,hs或者后缀数组都可以.然后dp[i][j] (0<i<len 0<=j< ...
- ZOJ People Counting
第十三届浙江省大学生程序设计竞赛 I 题, 一道模拟题. ZOJ 3944http://www.icpc.moe/onlinejudge/showProblem.do?problemCode=394 ...
- CTRL-Space always toggles Chinese IME (Windows 7、10)
一.window占用了ctrl+空格的快捷键,影响开发工具的只能提示的使用. 二.解决方式: Go to Start > Type in regedit and start it (打开运行输入 ...
- ZOJ 3686 A Simple Tree Problem
A Simple Tree Problem Time Limit: 3 Seconds Memory Limit: 65536 KB Given a rooted tree, each no ...
随机推荐
- JAVA中REPLACE和REPLACEALL的区别(转)
replace和replaceAll是JAVA中常用的替换字符的方法,它们的区别是: 1)replace的参数是char和CharSequence,即可以支持字符的替换,也支持字符串的替换(Char ...
- asp.net连接mysql数据库
方法一:使用MySQL推出的MySQL Connector/Net组件, 该组件是MySQL为ADO.NET访问MySQL数据库设计的.NET专用访问组件.完成该组件后,需要在项目中引用这个组件,也可 ...
- 总结&记录
一.Git(linux命令) 1.tar 压缩/解压 -c 建立一个压缩文件(create) -x 解压一个压缩文件 -t 查看tarfile中文件 -z 是否具有gzip的属性?是否需要用gzip ...
- VS2010 VS2012 如何连接Oracle 11g数据库
oracle是开发者常用的数据库,在做.NET开发是,由于Vs自带的驱动只能连接oracle 10g及以下版本,那么如何连接oracle 11g呢? 工具/原料 事先安装VS2010或者VS201 ...
- Java实战之02Hibernate-05检索策略、检索方式
十一.Hibernate的检索策略 1.概述: 查询的时机:什么时候去查? /** * 一张表的检索策略我们称之为: * 类级别的检索策略. * 注意:只要是说类级别的检索策略,就一定不涉及关联对象. ...
- VirtualBox single usermode boot
VirtualBox single usermode boot 当系统因为某些原因无法通过图形界面登录VirtualBox内的系统时,可以通过Grub进入命令行模式/单一用户界面模式. 参考: 1.R ...
- [PR & ML 4] [Introduction] Model Selection & The Curse of Dimension
这两部分内容比较少,都是直觉上的例子和非正式的定义,当然这本书中绝大多数定义都是非正式的,但方便理解.后面深入之后会对这两个章节有详细的阐述.
- 392. Is Subsequence
392. Is Subsequence 水题,先是判断长度,长度t比s小,返回false,然后从左到右扫描t,然后同时扫描s,如果相同,s的index就往后拉一个,如果s的index等于s长度,返回t ...
- Cannot connect to (local) sql server 2008
Make following steps to solve the issue: Cannot connect to (local). ADDITIONAL INFORMATION: Login fa ...
- SVN查看提交日志的命令
Windows下,使用svn客户端查看日志很方便,但是如果在linux下,常规查看日志的命令对于日志记录数比较多的时候,屏幕显示不了,就比较麻烦,后来发现了一个很有用的参数可以限制要查看的记录条数 查 ...