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

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

?:匹配一个或三个部分

!:匹配三个以上部分。

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

域名的长度不超过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. 0512 Scrum 项目3.0

    SCRUM 流程的步骤2: Spring 计划 1. 确保product backlog井然有序.(参考示例图1) 2. Sprint周期,一个冲刺周期,长度定为两周,本学期还有三个冲刺周期. 3. ...

  2. ASCII十进制字符集

    <script> for(var i=33;i<=6000;i++){ document.write("&nbsp"+i+"&nbsp ...

  3. Qt工程转化为Vs工程

    cmd中输入: qmake -tp vc XXX.pro 一般需要将qmake的路径配置到系统环境变量中去...

  4. 转AjaxControlToolkit的安装与使用详解

    AjaxControlToolkit的安装与使用详解 AjaxControlToolkit下载http://ajax.asp.net/downloads/default.aspx?tabid=47ht ...

  5. Xcode 8 的 Debug 新特性

    Contents OverView Static Analyzer Localizability Instance Cleanup Nullablility Runtime Issue View De ...

  6. 1057 N的阶乘(大数运算)

    题目链接:51nod 1057 N的阶乘 #include<cstdio> using namespace std; typedef long long ll; ; const int m ...

  7. guava学习--Ordering

    转载:http://www.cnblogs.com/peida/p/Guava_Ordering.html Ordering是Guava类库提供的一个犀利强大的比较器工具,Guava的Ordering ...

  8. alter table的用法

    在数据库开发过程中,除了用得最多的数据库查询外,我们有时也需要去修改数据表的定义,比如在已存在的数据表中新增列和删除列等.这篇文章就总结一下alter table语句的用法. 示例代码如下. USE ...

  9. iOS开发数据库篇—FMDB简单介绍

    iOS开发数据库篇—FMDB简单介绍 一.简单说明 1.什么是FMDB FMDB是iOS平台的SQLite数据库框架 FMDB以OC的方式封装了SQLite的C语言API 2.FMDB的优点 使用起来 ...

  10. shell使用随笔

    001 对文件某一列求和 awk '{sum += $collum};END {print sum}' /path/to/your/file 2 3 3 5 假设文件内容如上所示: # awk '{s ...