·你的目的就是要让编码有歧义,这就美妙了。

·英文题,述大意:

      给出n个模板字符串,询问是否存在一个字符串,使得用模板串(随便你用多少个)来拼凑这个串,能够至少有两种拼法。如果有,就输出“有”。

·分析:

     值得注意的是,n的范围不太大(0<n<101)。

     如果直接思考如何拼凑,那么就是一个典型的搜索枚举思想,对于这道题来说,也是一个典型的爆炸超时思想。不过,如果拥有一个好的习惯,你会不禁想到:正着不行反着来。所以,我们考虑对于一个串,把它切成几块,并使得每块都属于模板串。如果有两种切法,那么就可以输出“Yes”了。

比如这样:

·目的明确。对于一个串,我们将其切割,我们在将这样的状态重画一遍:

·玩着玩着,我们意识到:分成的小段一定是属于模板串的。所以考虑用模板串去填出大串(逆向思维已经贡献了它的全部加值,现在应该回来了)。

·分析一类简单情况,如图,我们要拼凑满足条件的大串:

·首先会拿上面两个模板串,就拼出了大串。然后你会拿下面两个模板串再来拼一个一样的大串,然后就可以输出“Yes”了。

·在反复拼凑的过程中,得到一些结论:
①每种拼法每一个位置上的字母上一样的(不要忽视)

②不同的拼法,所使用模板串时,发现只有部分重叠(相同)的模板串能够在靠近的位置,如图:

·可以看见,红串绿串有公共前缀,在不同拼法中起点相同;黄串与蓝串有公共后缀,在不同拼法中终点相同;红串与黄串的关系是:红串的一个后缀等于黄串的一个前缀,它们在不同拼法中收尾相接(部分重叠)。你可以在冥冥之中感受到,两种拼凑方式是有联系的,即这个串可能会“指导”另一个串的合成。

·神秘跳跳方法解决问题。我们用这样的顺序,来搭建这两个串:(结合上图吧)先在上面放置一个绿串,然后在模板中寻找前缀与它相同的串来搭建下面的串,于是找到了红串,将红串放置。现在红串伸出去了一截,在模板中寻找前缀与这一截相同的串,找到黄串,放在上面。现在黄串伸出去了一截,在模板串中寻找前缀与这一截相同的串,找到蓝串,放置蓝串于下方。发现没有那个伸出去一截了,也就是说,当前拼的大串,我们已经找到有两种拼法了。

·总结规律:只要还伸出去了一截,我们就永不停息,直到没有伸出的一截。说句老实话,找不到就是找不到,还是要停息的(不停息的现实意义就是超时)。

·方法:枚举两两模板串,并记录一个模板串的第i位开始,可以接上(即上文的相同)另一个串的开头(举例子就是红串的第6位开始可以接上黄串)。怎样表示关系呢?就建边把,将每一个模板串的每一位看成一个节点,然后就搭建有向边(比如红串第6位可一建一条边通向黄串第5位)。什么时候结束呢,如果从某个串i位到末尾就完全等于一个另一个模板串(就像上文黄串与蓝串的关系一样),就说明不会冒出一截了,也就是找到答案。

·代码(防水的)浮出水面:

 1 #include<stdio.h>
 2 #include<cstring>
 3 #define go(i,a,b) for(int i=a;i<=b;i++)
 4 #define fo(i,a,x) for(int i=a[x],v=e[i].v;i;i=e[i].next,v=e[i].v)
 5 const int N=110;struct E{int v,next;}e[N*300];
 6 int T,x,n,m,len[N],sz,ID[N][30],head[N*30],k,over;char s[N][30];bool vis[N*30],can;
 7 void ADD(int u,int v){e[k]=(E){v,head[u]};head[u]=k++;}
 8 void dfs(int u){if(can=u==over)return;vis[u]=1;fo(i,head,u)if(!vis[v]){dfs(v);if(can)return;}}
 9 int main(){while(scanf("%d",&x),can=sz=0,k=1,x)
10 {
11     go(i,1,x){scanf("%s%s",s[i]+1,s[i]+1);len[i]=strlen(s[i]+1);
12     go(j,1,len[i])vis[sz]=head[ID[i][j]=++sz]=0;}vis[sz+1]=0;
13
14     go(a,1,x){n=len[a];go(I,1,n){go(b,1,x){m=len[b];
15         if(a==b&&I==1)continue;int i=I-1,j=0;
16         while(s[a][++i]==s[b][++j]&&i<=n&&j<=m);
17         if(i>n&&j>m) ADD(ID[a][I],over);
18         if(i<=n&&j>m)ADD(ID[a][I],ID[a][i]);
19         if(i>n&&j<=m)ADD(ID[a][I],ID[b][j]);
20     }}}
21     go(i,1,x){if(!vis[ID[i][1]])dfs(ID[i][1]);if(can)break;}
22     printf("Case #%d: ",++T);puts(can?"Ambiguous.":"Not ambiguous.");
23 }return 0;}//Paul_Guderian

我无法忘记故乡秋末的麦地,
和南方水柳摇摆的倩影。——————汪峰《雨天的回忆》

转载于:https://www.cnblogs.com/Paul-Guderian/p/7029457.html

【Uva 11604 编码都有歧义了】相关推荐

  1. General Sultan UVA - 11604(建图暴力)

    给出n个字符串,询问是否存在一个字符串(可以是给出的几个中的 也可以是组合成的),使得用字符串(随便你用多少个)来拼凑这个串,能够至少有两种拼法 解析: 把每一个字符串的每一个位置的字符看作结点,进行 ...

  2. aptx与ldac音质区别_搞清楚LDAC、aptX这些蓝牙编码都有啥区别

    作为手机相当重要的一个配件, 蓝牙耳机现在可以说是很多人的必备品之一,这个带来极大的使用便利的产品,实际上发展的年头并不算很多.1994年爱立信研发出蓝牙技术,1997年被英特尔工程师命名为Bluet ...

  3. 中文乱码、英文数字正常,所有编码都试过了还是不能正常显示的解决办法

    工作中发现从某公司的BI系统中导出的csv文件,其中所有的中文字符都不能正常显示,但是英文.数字.换行符.Tab均正常显示. 使用Word和Notepad++,试了所有的Encoding,都不能正常所 ...

  4. aptx与ldac音质区别_买蓝牙耳机前,你或许该搞清楚LDAC、aptX这些蓝牙编码都有啥区别...

    作为手机相当重要的一个配件, 蓝牙耳机现在可以说是很多人的必备品之一,这个带来极大的使用便利的产品,实际上发展的年头并不算很多.1994年爱立信研发出蓝牙技术,1997年被英特尔工程师命名为Bluet ...

  5. UVA - 11604 General Sultan 题解

    题目大意: 有若干模式串,将某些模式串拼接起来(一个可以使用多次)形成一个长模式串,判断能否有两种或更多种不同的拼法拼成相同的模式串. 思路: 神奇的构图,暴力的求解. 可以发现,若有不同的拼法,则一 ...

  6. UVA - 11604 General Sultan

    对每两个字符串进行匹配然后连边=看程序应该能看懂 开始st没清零不停地爆oj #include <cstdio> #include <cstring> #include < ...

  7. 关于字符编码,你所需要知道的(ASCII,Unicode,Utf-8,GB2312…)

    字符编码的问题看似很小,经常被技术人员忽视,但是很容易导致一些莫名其妙的问题.这里总结了一下字符编码的一些普及性的知识,希望对大家有所帮助. 还是得从ASCII码说起 说到字符编码,不得不说ASCII ...

  8. 关于字符编码,你所需要知道的

    起源 字符编码的问题看似很小,经常被技术人员忽视,但是很容易导致一些莫名其妙的问题.这里总结了一下字符编码的一些普及性的知识,希望对大家有所帮助. 还是得从ASCII码说起 说到字符编码,不得不说AS ...

  9. 【转】关于字符编码,你所需要知道的

    字符编码的问题看似很小,经常被技术人员忽视,但是很容易导致一些莫名其妙的问题.这里总结了一下字符编码的一些普及性的知识,希望对大家有所帮助. 还是得从ASCII码说起 说到字符编码,不得不说ASCII ...

最新文章

  1. Udacity机器人软件工程师课程笔记(二十一) - 对点云进行集群可视化 - 聚类的分割 - K-means|K均值聚类, DBSCAN算法
  2. Docker之tomcat和nginx的部署
  3. 微软.NET年芳15:我在Azure上搭建Photon服务器(C#.NET)
  4. 两步验证杀手锏:Java 接入 Google 身份验证器实战
  5. python导出excel文件数字签名_Python使用RSA+MD5实现数字签名
  6. 如何在 Flink 中规划 RocksDB 内存容量?
  7. 非职业程序员的工具箱
  8. PHP数据结构预热:PHP的迭代器(转)
  9. DelphiXE4发布了
  10. web`2019.2.28~MY g~
  11. Linux操作系统中修改hostname
  12. Mybatis高级映射一对一查询
  13. echars的矩形数图根据大小根据一个值变化,颜色跟随另外一个值变化
  14. 【ArcGIS|空间分析】栅格数据和矢量数据的面积计算
  15. 如何通过组策略来缓解打印机后台处理程序漏洞CVE-2021-34527?
  16. 在windows中桌面显示itunes音乐滚动歌词
  17. 负熵作为非高斯的度量
  18. 全国大江大河实时水情数据下载
  19. CSS二(复合选择器)
  20. element-UI中使用树组件el-tree实现左侧勾选右侧列表展示并且列表删除某一项左侧树菜单取消相应勾选

热门文章

  1. 全文检索技术 mysql_浅谈MYSQL的全文检索的应用
  2. python xml转字典_python xml转成dict
  3. 用python读取图像_如何用python获取图像
  4. 如何检查Python字典中是否存在密钥
  5. sql主键_SQL主键
  6. Python Gensim Word2Vec
  7. Java LocalTime
  8. Java字符串equals()
  9. easymock使用方法_EasyMock无效方法– ExpectLastCall()
  10. 微信上如何发送GIF动图