给你两个域名,域名中包含一些通配符。

* :匹配一个或任意多个部分

?:匹配一个或三个部分

!:匹配三个以上部分。

求这两个域名是否能够表示同一个域名?

域名的长度不超过255.

分析:设给出的域名为A,B,以f[i][j]表示域名A的前i个部分和域名B的前j个部分是否可能相同。类似于求最长公共子串的转移方式。

f[i][j]=f[i-1][j-1]||f[i][j-1] 如果A[i]是*号。

f[i][j]=f[i-1][j-1]||f[i-1][j-2]||f[i-1][j-3]  //如果A[i]是?号,但这么写是有问题的。如果B[j]也是通配符,就错了。

于是我们势必将A[i]和B[j]一起考虑。这里就会有最多16种情况,当然其中有些情况可以合并。

但是仍然有问题。比如A[i]是?号,B[j]是?号。

如果方程这样写:f[i][j]=f[i-1][j-1]||f[i-1][j-2]||f[i-1][j-3]||f[i-2][j-1]||f[i-3][j-1] ,则如果B[j-1]是!号,则有问题。

如果方程这样写:f[i][j]=f[i-1][j-1]||f[i][j-1]||f[i-1][j],则如果f[i][j-1]=1,但此时A[i]已经表示了三个部分了,没办法再表示B[j]了,又怎么办呢?

所以这种转移是很不好办的。

我们感觉到,如果通配符只能表示0个,1个或任意多个是比较好处理的。所以,我们将原有的通配符做一个转换。

*意义不变

?变成只能匹配一个部分

!变成只能匹配0个或1个部分。

则原来的?=?!!(新符号)

原来的!=??*

这样的话,就好处理多了。

先考虑*号,再考虑!号,再考虑?或非通配符。具体转移看代码。

 #include<iostream>
#include<cstdio>
#include<sstream>
#include<cstring>
#include<algorithm>
using namespace std;
int n,cas;
#define MAXN 800
char s[MAXN][MAXN],t[MAXN][MAXN];
char ss[MAXN],tt[MAXN];
bool f[MAXN][MAXN];
int cnt1=,cnt2=,pos=;
int convert(char *ss,char s[][MAXN])
{
int cnt=,pos=;
int slen=strlen(ss);
for(int i=;i<slen;i++)
{
if(ss[i]!='.')
{
if(ss[i]=='!')
{s[cnt++][]='?';
s[cnt++][]='?';
s[cnt][]='*';
}
else if(ss[i]=='?')
{
s[cnt++][]='?';
s[cnt++][]='!';
s[cnt][]='!';
}
else s[cnt][pos++]=ss[i];
}
else
cnt++,pos=;
}
return cnt;
}
int main()
{
scanf("%d\n",&cas);
while(cas--)
{
memset(f,,sizeof f);
memset(s,,sizeof s);
memset(t,,sizeof t);
gets(ss);
//cerr<<ss<<endl;
gets(tt);
//cerr<<tt<<endl;
cnt1=convert(ss,s);
cnt2=convert(tt,t);
f[][]=;
for(int i=;i<=cnt1;i++)
for(int j=;j<=cnt2;j++)
{
if(s[i][]=='*')
f[i][j]=f[i][j]||f[i][j-]||f[i-][j-];
if(t[j][]=='*')
f[i][j]=f[i][j]||f[i-][j]||f[i-][j-]; else if(s[i][]=='!')
f[i][j]=f[i][j]||f[i-][j]||f[i-][j-];
else if(t[j][]=='!')
f[i][j]=f[i][j]||f[i][j-]||f[i-][j-];
else if(s[i][]=='?'||t[j][]=='?')
{
f[i][j]=f[i][j]||f[i-][j-];
}
else if(strcmp(s[i],t[j])==)
f[i][j]=f[i-][j-];
}
if(f[cnt1][cnt2]==)
printf("NO\n");
else printf("YES\n");
}
}

POJ1229 域名匹配的更多相关文章

  1. Apache 配置两个域名匹配的文件夹和配置多个Web站点

    Apache的虚拟主机是一种同意在同一台机器上,执行超过一个站点的解决方式,同一时候也就能够邦迪二级域名到指定的文件夹.虚拟主机有两种.一种叫基于IP的(IP-based),还有一种叫基于名字的(na ...

  2. 【Nginx入门系列】第四章 通过域名匹配虚拟主机,不修改端口

    域名访问原理 我们在显示生活中,我们怎样通过一个域名来访问到我们所需要的网站呢? 例如www.baidu.com,我们在浏览器输入百度网址会先发送请求到DNS服务器,DNS会通过我们的域名解析百度对应 ...

  3. tomcat匹配请求流程(原创)

    tomcat8.0.36 配置Connector属性allowTrace为true时,允许TRACE方法,默认禁止. tomcat8.0.36有一个BUG,该BUG在8.0.37里被修复,就是一个解析 ...

  4. tomcat对请求路径的匹配过程(原创)

    1.匹配服务 如果有两个应用,一个应用只能通过80端口访问,另一个应用只能通过8080端口访问,这种情况下,可以分开两个服务,然后分别创建80端口和8080端口的连接器. 2.匹配主机 一个服务下配置 ...

  5. nginx多域名配置

    方法一:多个.conf方法(优点是灵活,缺点就是站点比较多配置起来麻烦) 这里以配置2个站点(2个域名)为例,n 个站点可以相应增加调整,假设: IP地址: 192.168.1.100域名1 exam ...

  6. Nginx的虚拟服务器域名配置

    虚拟服务器名(server name)是通过指令server_name来指定的.在< Nginx是如何处理Request的?>一节中,我们讲到nginx分两步来匹配过来的Request请求 ...

  7. DNS Wildcard(DNS泛域名)

    在DNS中,泛域名(wildcard Resource Record)可以被认为是一种合成RR的机制,借助于它,DNS服务器可以响应本来不存在的域名的请求,它的设计初衷是用来把所有邮件都转发到一个邮件 ...

  8. 关于 Cookie-free Domains (为什么将静态图片,js,css存放到单独的域名?)

    这篇文章对高性能web开发具有参考性:http://developer.yahoo.com/performance/rules.html 本文主要描述使用裸域名做网站主域名时,如何用子域名做 cook ...

  9. .Net Core 二级域名绑定到指定的控制器

    在说二级域名绑定之前,先说一下.net core中的区域,关于区域这一块儿在很久之前的博客中,已经提过,详见<03-dotnet core创建区域[Areas]及后台搭建>,在这篇博客中, ...

随机推荐

  1. JS的学习体会与分享

    最近在学习js这门计算机网络的新知识.相比与之前所学习的html和css这两门编程语言,js 还是有很多的不同之处,它相比于前两门知识还是有一定的难度和逻辑性的.今天跟大家分享一篇文章,希望能从中获得 ...

  2. docker初学笔记

    什么是docker 不准确的说,docker是一种轻量级的虚拟机,它把可执行文件和运行环境打包成一个image,放在容器里运行,但是启动速度比虚拟机快很多,资源消耗小.这种技术主要是为了解决部署环境的 ...

  3. python讲一个列表写入excel表中

    连接为http://blog.csdn.net/a491057947/article/details/47614263 http://www.crifan.com/export_data_to_exc ...

  4. HDU 1402 fft 模板题

    题目就是求一个大数的乘法 这里数字的位数有50000的长度,按平时的乘法方式计算,每一位相乘是要n^2的复杂度的,这肯定不行 我们可以将每一位分解后作为系数,如153 = 1*x^2 + 5*x^1 ...

  5. Java 导出EXCEL

    1.Apache POI简介 Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程式对Microsoft Office格式档案读和写的功能. .NET的开发人员则 ...

  6. Sql获取第一天、最后一天

    昨天面试一家公司,上机题目中要求获取每月最后一笔订单.用到了日期的选择性查询,回来在ITeye上找到了这篇文章. 原文: http://new-fighter.iteye.com/blog/17587 ...

  7. jQueryMobile控件之页面切换

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. Reverse-Daily(2)-wow

    链接:http://pan.baidu.com/s/1eS9JNP4 密码:ltl4 本体分析比较简单,算法是解一个22元一次方程 这里引入了numpy这样一个python库,灰常强大 import ...

  9. H5实现俄罗斯方块(四)

    图片加载的js: (function (window) { 'use strict'; //定义缓存的Map对象 var cacheMap = new Map(); //资源的总数量 var reso ...

  10. C#代码示例_集合

    C#中数组实现为System.Array类得实例,它们只是集合类(Collection Classes)中的一种类型. 索引符(indexer)是一种特殊类型的属性,可以把它添加到一个类中,以提供类似 ...