题意:给定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的更多相关文章

  1. 数学+高精度 ZOJ 2313 Chinese Girls' Amusement

    题目传送门 /* 杭电一题(ACM_steps 2.2.4)的升级版,使用到高精度: 这次不是简单的猜出来的了,求的是GCD (n, k) == 1 最大的k(1, n/2): 1. 若n是奇数,则k ...

  2. zoj 2313 Chinese Girls' Amusement 解题报告

    题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1313 题目意思:有 N 个人(编号依次为1~N)围成一个圆圈,要求求 ...

  3. ASC #1

    开始套题训练,第一套ASC题目,记住不放过每一题,多独立思考. Problem A ZOJ 2313 Chinese Girls' Amusement 循环节 题意:给定n,为圆环长度,求k < ...

  4. 使用MySQL数据库将汉字转换成拼音的一个C语言小程序

    环境: mysql:mysql-5.1.65 centos:centos 6.5 编译命令: gcc -o chinesetopinyin chinesetopinyin.c -L/usr/lib/m ...

  5. 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 ...

  6. ZOJ 3817Chinese Knot(The 2014 ACM-ICPC Asia Mudanjiang Regional First Round)

    思路: 将4个串每个串都反向这样得到新的四个串一共8个串,对于母串每个位置检测这个串能不能放进去,hs或者后缀数组都可以.然后dp[i][j]  (0<i<len  0<=j< ...

  7. ZOJ People Counting

    第十三届浙江省大学生程序设计竞赛 I 题, 一道模拟题. ZOJ  3944http://www.icpc.moe/onlinejudge/showProblem.do?problemCode=394 ...

  8. CTRL-Space always toggles Chinese IME (Windows 7、10)

    一.window占用了ctrl+空格的快捷键,影响开发工具的只能提示的使用. 二.解决方式: Go to Start > Type in regedit and start it (打开运行输入 ...

  9. ZOJ 3686 A Simple Tree Problem

    A Simple Tree Problem Time Limit: 3 Seconds      Memory Limit: 65536 KB Given a rooted tree, each no ...

随机推荐

  1. Base64 编码

    Base64 字母表 Base64 编码将一个 8 位字节序列拆成 6 位的片段,并为每个 6 位的片段分配一个字符,这个字符是 Base64 字母表中的 64 个字符之一. Wert Zeichen ...

  2. linux添加用户、用户组、权限

    # useradd –d /usr/sam -m sam 此命令创建了一个用户sam,其中-d和-m选项用来为登录名sam产生一个主目录/usr/sam(/usr为默认的用户主目录所在的父目录). 假 ...

  3. ora 32021 设置参数时参数值长度超过255处理办法

    alter system set db_file_name_convert='AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA-.' scope=spfi ...

  4. iOS 键盘回收实现步骤

    第一步:遵守协议 (UITextFieldDelegate) @interface AppDelegate : UIResponder <UIApplicationDelegate,UIText ...

  5. NSMutableAttributedString(富文本)的简单使用

    #import "ViewController.h" @interface ViewController () @end @implementation ViewControlle ...

  6. .Net 程序集 签名工具sn.exe 密钥对SNK文件 最基本的用法

    阐述签名工具这个概念之前,我先说说它不是什么: 1.它不是用于给程序集加密的工具,它与阻止Reflector或ILSpy对程序集进行反编译一毛钱关系都没有. 2.它很讨厌人们把它和加密联系在一起. 我 ...

  7. json字符串转JSONObject,输出JSONObject问题

    json架包:json-lib-2.4-jdk15.jar json字符串(存在null值)转JSONObject 后return JSONObject对象的时候会报错 例如: String str= ...

  8. JDBC访问SQLServer2008数据库

    来源:十二随风博客 由JDBC驱动直接访问数据库优点:100% Java,快又可跨平台缺点:访问不同的数据库需要下载专用的JDBC驱动 (1)下载对应数据库版本的jdbc驱动并安装,注意安装后的得到的 ...

  9. Java Web开发之详解JSP

    JSP作为Java Web开发中比较重要的技术,一般当作视图(View)的技术所使用,即用来展现页面.Servlet由于其本身不适合作为表现层技术,所以一般被当作控制器(Controller)所使用, ...

  10. 解决laravel中环境配置不起作用的方法

    博客已经迁移到www.imyzf.com,本站不再更新,请谅解! laravel有个环境配置选项很好用,在bootstrap/start.php中,曾经百度到这里面加入域名,就可以自动选择环境 $en ...