求最大的公共前缀;

用后缀数组做;

其实暴力也可以过;

 #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. C# 判断路径是否存在

    定义文件状态枚举:0-路径为空,1-存在文件,2-路径不为空,但文件不存在 public enum FileExsitStatus { NoPath=0, FileExsit=1, NoFile=2 ...

  2. 까페24 호스팅 php 에러메세지 출력

    [문제점] 최근 까페24호스팅에서 php작업시화면에 에러메세지가 나오지 않아 디버깅시에 매우 곤란함 [해결책] .htaccess 내용에 아래추가.=================== ...

  3. iis7下.Net框架版本设置

    转载:http://blog.163.com/fan_yishan/blog/static/47692213201391651229542/ Win7下IIS网站的.Net框架版本设置 步骤/方法 1 ...

  4. 转:Unity3D的四种坐标系

    World Space(世界坐标):我们在场景中添加物体(如:Cube),他们都是以世界坐标显示在场景中的.transform.position可以获得该位置坐标. Screen Space(屏幕坐标 ...

  5. Java 简单算法--排序

    1. 冒泡排序 package cn.magicdu.algorithm; public class BubbleSort { public static void main(String[] arg ...

  6. Android开发之BroadcastReceiver

    BroadcastReceiver:广播接收者.用来接收系统或应用中的广播. 在Android系统中,广播体现在方方面面,例如当开机完成后系统会产生一条广播,接收到这条广播就能实现开机启动服务的功能: ...

  7. iOS-学习路线图(推荐)

    在学习一个新的知识时,除了保持积极的态度.对知识的渴望,学习路线以及方法也是很重要的.在学习iOS的时候,遇到这样的情况,非常想去学习,提高,但是没有一个学习路线,不知道从哪里入手,该先学什么.在学什 ...

  8. OC2_分数类

    // // Fraction.h // OC2_分数类 // // Created by zhangxueming on 15/6/10. // Copyright (c) 2015年 zhangxu ...

  9. libjingle线程机制

    libjingle包装了所有的线程,包括signaling thread,worker thread, 和其它任何线程,用talk_base::Thread来包装.所有的 Thread对象由Threa ...

  10. MyBatis入门教程(基于Mybatis3.2)

    MyBatis和Hibernate一样都是基于ORM的关系型数据库框架 ORM工具的基本思想: 1.从配置文件(通常是XML配置文件中)得到 sessionfactory. 2. 由sessionfa ...