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

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

?:匹配一个或三个部分

!:匹配三个以上部分。

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

域名的长度不超过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. MVC5 + EF6 入门完整教程一:从0开始

    第0课 从0开始 ASP.NET MVC开发模式和传统的WebForm开发模式相比,增加了很多"约定". 直接讲这些 "约定" 会让人困惑,而且东西太多容易忘记 ...

  2. JQ判断屏幕宽度

    <script> if (screen.width < 768){....} </script>

  3. iOS开发网络篇—HTTP协议

    iOS开发网络篇—HTTP协议 说明:apache tomcat服务器必须占用8080端口 一.URL 1.基本介绍 URL的全称是Uniform Resource Locator(统一资源定位符) ...

  4. 黑马程序员——OC语言 核心语法 (3)

    Java培训.Android培训.iOS培训..Net培训.期待与您交流! (以下内容是对黑马苹果入学视频的个人知识点总结) (一)分类Category 1) 基本用途 如何在不改变原来类模型的前提下 ...

  5. 【转】ora-00031:session marked for kill处理oracle中杀不掉的锁

    一些ORACLE中的进程被杀掉后,状态被置为"killed",但是锁定的资源很长时间不释放,有时实在没办法,只好重启数据库.现在提供一种方法解决这种问题,那就是在ORACLE中杀不 ...

  6. 关于ASP.NET或VS2005 搭建三层架构的理解

    最近想学习ASP.NET建网站,关于ASP.NET或VS2005 搭建三层架构的理解,网上摘录了一些资料,对于第(2)点的讲解让我理解印象深刻,如下: (1)为何使用N层架构? 因为每一层都可以在仅仅 ...

  7. Python开发入门与实战3-Django动态页面

    3.Django动态页面 上一章节我们实现的helloworld视图是用来演示Django网页是创建的,它不是一个动态网页,每次运行/helloworld/,我们都将看到相同的内容,它类似一个静态HT ...

  8. 【转】NHibernate:no persister for 异常

    1.配置文件后缀名写错 mapping file 必须是.hbm.xml结尾 2.Web.config配置里面引用实体 <session-factory> <mapping asse ...

  9. The Layout Process on Mac OSX and iOS

    First we will recap the steps it takes to bring views on screen with Auto Layout enabled. When you’r ...

  10. Android控件— — —ImageView

    <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android=" ...