棋局定式

【问题描述】

在“jloi-08”游戏中,还存有非常非常多的棋局定式,也就是常会用到的下棋的组合。有时在学习一个著名棋局时,电脑会考一考刘先生:在这局棋里面,有多少个定式啊?分别是什么啊?

 

对于30~40步的普通棋局,刘先生还能回答出来,可是有时候2个实力相当的大牛下的棋局,2000000步都有可能。如果电脑对这样的棋局提上面的问题时,刘先生就必须写一个程序来帮助自己了。可是,刘先生在这方面却,怎么写也写不对。你能帮助刘先生吗?

 

棋局是由很多step组成的,而step是由一个字符串组成的,比如Kh2或者是Nxb7

前者表示K(king)移动至h2格,后者表示N(knight)移动至b7格并吃掉原有的棋子。

 

第一个字符可能有6种:K Q B N R P,而后面可能是一个坐标或者是字符x后跟一个坐标。

 

坐标是由一个小写英文字母(a~h)和一个数字(1~8)组成的。

 

如果一个棋局中完整地并连续地包含一个定式中所有的step,那么这个棋局便包含这个定式。

 

【输入】

 

第一行2个整数n, m,表示定式的个数(1<=n<=2000)以及这个棋局所包含的步数

 

下面的n个块(block),每块包含:

第一行一个整数k表示定式包含的步数(1<=k<=100000, ∑k<=200000)

第二行一个字符串表示该定式的名称(长度不超过50)

下面的k行每行一个字符串表示定式中的一步

 

最后的m行每行一个字符串,表示棋局中的一步

 

【输出】

 

按照输入文件包含的定式的顺序,输出棋局包含的所有定式的名称,一个一行。

 

【样例输入输出】

 

master.in

2 5

3

King's Knight Opening

Pe4

Pe5

Nf3

3

Nimzowitsch Variation

Pc4

Pe5

Nf3

Pe4

Pe5

Nf3

Nc6

Bb5

 

master.out

 

King's Knight Opening

 

Hint

 

不保证给出的棋局和定式符合国际象棋的规则。

 

posted on 2009-03-11 03:51 250 阅读(133) 评论(0)  编辑 收藏 引用

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


<2024年4月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

留言簿(6)

随笔分类

随笔档案

文章档案

相册

搜索

  •  

最新评论