求最大的公共前缀;

用后缀数组做;

其实暴力也可以过;

 #include<cstdio>
#include<cstring>
#include<algorithm>
#define maxn 2009
using namespace std; int s[maxn];
int sa[maxn],t[maxn],t2[maxn],c[maxn],n; void build_sa(int m)
{
int *x=t,*y=t2;
for(int i=; i<m; i++)c[i]=;
for(int i=; i<n; i++)c[x[i]=s[i]]++;
for(int i=; i<m; i++)c[i]+=c[i-];
for(int i=n-; i>=; i--)sa[--c[x[i]]]=i;
for(int k=; k<=n; k<<=)
{
int p=;
for(int i=n-k; i<n; i++)y[p++]=i;
for(int i=; i<n; i++)if(sa[i]>=k)y[p++]=sa[i]-k;
for(int i=; i<m; i++)c[i]=;
for(int i=; i<n; i++)c[x[y[i]]]++;
for(int i=; i<m; i++)c[i]+=c[i-];
for(int i=n-; i>=; i--)sa[--c[x[y[i]]]]=y[i];
swap(x,y);
p=;
x[sa[]]=;
for(int i=; i<n; i++)
x[sa[i]]=y[sa[i-]]==y[sa[i]]&&y[sa[i-]+k]==y[sa[i]+k]?p-:p++;
if(p>=n)break;
m=p;
}
} int rank[maxn],height[maxn];
void getheight()
{
int k=;
for(int i=; i<n; i++)rank[sa[i]]=i;
for(int i=; i<n; i++)
{
if(k)k--;
int j=sa[rank[i]-];
while(s[i+k]==s[j+k])k++;
height[rank[i]]=k;
}
} bool check(int mid)
{
int mi=,ma=-;
for(int i=; i<n; i++)
{
if(height[i]>=mid)
{
mi=min(mi,sa[i]);
ma=max(ma,sa[i]);
}
else
{
if(ma-mi>=mid)return ;
mi=ma=sa[i];
}
}
if(ma-mi>=mid)return ;
return ;
} bool isbad[];
char bad[],good[];
int main()
{
int tt,r,ca=;
scanf("%d",&tt);
getchar();
while(tt--)
{
memset(isbad,,sizeof isbad);
gets(good);
gets(bad);
int l=strlen(bad);
for(int i=; bad[i]!='\0'; i++)
isbad[bad[i]]=;
n=strlen(good);
while(n>&&good[n-]==' ')
{
good[n-]='\0';
--n;
}
int xx='z';
for(int i=; good[i]!='\0'; i++)
{
if(isbad[good[i]])s[i]=xx++;
else s[i]=good[i];
}
s[n]=;
if (n<=)
{
printf("Case #%d: 0\n",ca++);
continue;
}
n++;
build_sa(xx+);
getheight();
l=,r=n>>;
while(l<=r)
{
int mid=(l+r)>>;
if(check(mid))l=mid+;
else r=mid-;
}
printf("Case #%d: %d\n",ca++,r);
}
return ;
}

UVA 11739 Giving Candies的更多相关文章

  1. UVA - 10118 Free Candies 记忆化搜索经典

    思路:d[a][b][c][d]表示从已经第一个篮子取了a颗糖,第二个取了b颗糖,第三个取了c颗糖,第四个取了d颗糖最多还能够获得多少糖果.首先明白一个问题:如果能分别取a,b,c,d个,不论如何取, ...

  2. UVA 10118 Free Candies

    https://vjudge.net/problem/UVA-10118 题目 桌上有4堆糖果,每堆有$N$($N\leqslant 40$)颗.有个熊孩子拿了个可以装5颗糖的篮子,开始玩无聊的装糖游 ...

  3. UVa 10118 Free Candies (记忆化搜索+哈希)

    题意:有4堆糖果,每堆有n(最多40)个,有一个篮子,最多装5个糖果,我们每次只能从某一堆糖果里拿出一个糖果,如果篮子里有两个相同的糖果, 那么就可以把这两个(一对)糖果放进自己的口袋里,问最多能拿走 ...

  4. UVA - 10118 Free Candies(免费糖果)(dp---记忆化搜索)

    题意:桌上有4堆糖果,每堆有N(N<=40)颗.佳佳有一个最多可以装5颗糖的小篮子.他每次选择一堆糖果,把最顶上的一颗拿到篮子里.如果篮子里有两颗颜色相同的糖果,佳佳就把它们从篮子里拿出来放到自 ...

  5. [LeetCode] Candy 分糖果问题

    There are N children standing in a line. Each child is assigned a rating value. You are giving candi ...

  6. 6 Candy_Leetcode

    There are N children standing in a line. Each child is assigned a rating value. You are giving candi ...

  7. Leetcode Candy

    There are N children standing in a line. Each child is assigned a rating value. You are giving candi ...

  8. leetcode bugfree note

    463. Island Perimeterhttps://leetcode.com/problems/island-perimeter/就是逐一遍历所有的cell,用分离的cell总的的边数减去重叠的 ...

  9. LeetCode 135 Candy(贪心算法)

    135. Candy There are N children standing in a line. Each child is assigned a rating value. You are g ...

随机推荐

  1. 关于struts2的上传和下载

    1. 1文件上传技术: JSPSmartUpload:应用在Model1年代.(嵌入到JSP) FileUpload:应用在Model2年代. Servlet3.o:完成文件上传. Struts2框架 ...

  2. java面板

    import java.awt.Color; import java.awt.Container; import javax.swing.JFrame; import javax.swing.JLab ...

  3. json解析日期方法 问题的解决方案

    之前在做项目的时候发现,用json格式传输日期数据的时候,发现从数据库中传回到页面的数据出现错误,查阅相关资料才知道,原来json不支持日期解析,要自己解决,解决方案也很简单,写一段js代码就OK了- ...

  4. Android IntentService使用

    因为多数启动服务不必同时处理多个请求(在多线程情景下会很危险),所以使用IntentService类实现服务是很好的选择.本经验将通过继承IntentService输出当前时间教大家如何使用Inten ...

  5. PHP实现http与https转化

    http://zyan.cc/post/142/ 最近在写PHP程序时,需要使浏览器在https和http之间转化,上网搜索相关信息,无奈只有最近在写PHP程序时,需要使浏览器在https和http之 ...

  6. WCF编程系列(六)以编程方式配置终结点

    WCF编程系列(六)以编程方式配置终结点   示例一中我们的宿主程序非常简单:只是简单的实例化了一个ServiceHost对象,然后调用open方法来启动服务.而关于终结点的配置我们都是通过配置文件来 ...

  7. Apache中的权限设置

        今天,我们的关注点就集中在 order deny,allow 这个语句中.在网上找了些资料,对它有了一些了解,写在这儿. 我们可能对apache中这个权限设置可能不太清楚,不同的顺序对权限到底 ...

  8. TimesTen ODBC 链接库差异及相关命令行工具的使用注意事项

    1. TimesTen有两种访问模式:Direct模式和Client/Server模式,以下为来自Operations Guide 的描述 Connecting using TimesTen ODBC ...

  9. Wix: Using Patch Creation Properties - Small Update

    Source Reference: wix help document  -- WiX Toolset License Using Patch Creation Properties  A patch ...

  10. ExtJs 添加员工 实例 ---- 锚点布局 anchor 可自动伸缩

    代码如下: <script type="text/javascript"> Ext.onReady(function () { // 创建一条记录行, job 为 di ...