Preparing NOJ

正则表达式匹配问题

1000ms 65536K

Description:

许多操作系统采用正则表达式实现文件匹配功能。一种简单的正则表达式由英文字母、数字及通配符“*”和“?”组成。“?”代表任意一个字符。“*”则可以代表任意多个字符。现要用正则表达式对部分文件进行操作。

试设计一个算法,找出一个正则表达式,使其能匹配的待操作文件最多,但不能匹配任何不进行操作的文件。所找出的正则表达式的长度还应是最短的。

对于给定的待操作文件,找出一个能匹配最多待操作文件的正则表达式。

Input:

输入由n1n250)行组成。每行给出一个文件名。文件名由英文字母和数字组成。英文字符要区分大小写,文件名长度不超过8个字符。文件名后是一个空格符和一个字符“+”或“-”。“+”表示要对该行给出的文件进行操作,“-”表示不进行操作。

Output:

输出计算出的最多文件匹配数和最优正则表达式。第1行中的数是计算出的最多文件匹配数。第1行是最优正则表达式。

Sample Input:

EXCHANGE +
EXTRA +
HARDWARE +
MOUSE -
NETWORK -

Sample Output:

3
*A*

Note:

undefined

本题由旧版NOJ导入,来源:算法设计与实验题解

Info

NOJ

Provider NOJ

Code NOJ1233

Tags

Submitted 0

Passed 0

AC Rate 0%

Date 04/20/2019 10:03:10

Related

Nothing Yet