[Contest20180311]朋友
是毒瘤的friends呢~

注意到“产生感情”和后缀自动机的$Right$集合定义很像,所以先对所有串建广义sam,那么一个节点$s$里的所有串都互相产生感情,而从起点走到$s$走最长路所经过的节点里的串都和$s$的串认识(因为是前缀关系)
所以这题其实是求用最少的仅在起点相交的链覆盖广义sam
把每个节点拆成两个点,连一条容量限制为$[1,1]$的边,对于所有原sam中的转移,连一条边$[0,1]$,最后新建一个汇点,把所有非起点的点连一条$[0,1]$到汇点,跑最小流即可
这样做保证每个点都仅被经过一次且路径不相交
关于上下界网络流,可以去看一看zyz的博客,这里不乱写了
p.s.dicnic加了优化真的是可以为所欲为的,不加就直接被kill掉,加了就100msA掉,代码中有注释符号的地方就是优化
#include<stdio.h>
#include<string.h>
#define inf 10000000
int min(int a,int b){return a<b?a:b;}
namespace gra{
int h[20010],cur[20010],to[300010],nex[300010],cap[300010],M=1,s,t,ss,tt;
bool ex[300010];
void eadd(int a,int b,int c,bool d){
M++;
to[M]=b;
cap[M]=c;
ex[M]=d;
nex[M]=h[a];
h[a]=M;
M++;
to[M]=a;
cap[M]=0;
nex[M]=h[b];
h[b]=M;
}
int dis[20010],q[140010];
bool bfs(){
int head=1,tail=1,x,i;
q[1]=ss;
memset(dis,-1,sizeof(dis));
dis[ss]=0;
while(head<=tail){
x=q[head];
head++;
for(i=h[x];i;i=nex[i]){
if(dis[to[i]]==-1&&cap[i]>0){
dis[to[i]]=dis[x]+1;
if(to[i]==tt)return 1;//
tail++;
q[tail]=to[i];
}
}
}
return dis[tt]>0;
}
int dfs(int x,int flow){
if(x==tt)return flow;
int i,f;
for(i=cur[x];i;i=nex[i]){//
if(cap[i]>0&&dis[to[i]]==dis[x]+1){
f=dfs(to[i],min(flow,cap[i]));
if(f){
cap[i]-=f;
cap[i^1]+=f;
if(cap[i])cur[x]=i;//
return f;
}
}
}
dis[x]=-1;//
return 0;
}
int dicnic(){
int ans=0,tmp;
while(bfs()){
memcpy(cur,h,sizeof(h));//
while(tmp=dfs(ss,inf))ans+=tmp;
}
return ans;
}
void gao(){
dicnic();
eadd(t,s,inf,0);
s=dicnic();
for(int i=2;i<=M;i++){
if(ex[i]&&cap[i]!=0){
s=0;
break;
}
}
printf("%d",s);
}
}
namespace str{
struct sam{
int ch[1010],fa,v;
}t[10010];
int M=1;
int extend(int p,int c){
int q,nq;
if(t[p].ch[c]){
q=t[p].ch[c];
if(t[q].v==t[p].v+1)
return q;
else{
nq=++M;
t[nq]=t[q];
t[nq].v=t[p].v+1;
t[q].fa=nq;
while(p&&t[p].ch[c]==q){
t[p].ch[c]=nq;
p=t[p].fa;
}
return nq;
}
}else{
int np=++M;
t[np].v=t[p].v+1;
while(p&&t[p].ch[c]==0){
t[p].ch[c]=np;
p=t[p].fa;
}
if(p==0)
t[np].fa=1;
else{
q=t[p].ch[c];
if(t[q].v==t[p].v+1)
t[np].fa=q;
else{
nq=++M;
t[nq]=t[q];
t[nq].v=t[p].v+1;
t[np].fa=t[q].fa=nq;
while(p&&t[p].ch[c]==q){
t[p].ch[c]=nq;
p=t[p].fa;
}
}
}
return np;
}
}
int x[5010];
void gao(){
int k,m,n,i,j;
scanf("%d%d",&k,&m);
while(m--){
scanf("%d",&n);
i=1;
while(n--){
scanf("%d",&j);
i=extend(i,j);
}
}
gra::s=1;
gra::t=M+1;
gra::ss=M<<1|1;
gra::tt=(M<<1)+2;
for(i=1;i<=k;i++){
if(t[1].ch[i])gra::eadd(1,t[1].ch[i],inf,0);
}
for(i=2;i<=M;i++){
gra::eadd(gra::ss,i+M,1,1);
gra::eadd(i,gra::tt,1,1);
for(j=1;j<=k;j++){
if(t[i].ch[j])gra::eadd(i+M,t[i].ch[j],1,0);
}
gra::eadd(i+M,M+1,1,0);
}
}
}
int main(){
str::gao();
gra::gao();
}
[Contest20180311]朋友的更多相关文章
- QQ空间/朋友圈类界面的搭建
类似于QQ空间的布局主要是在说说信息.点赞.回复三大部分的自适应布局上. 当我们需要搭建类似QQ空间.微信朋友圈的界面的时候,可做如下操作: 创建一个对应的model类: 创建一个对应model类的f ...
- 2017《时间的朋友》罗振宇跨年演讲ppt
2016年12月31日晚,罗辑思维的罗振宇将在深圳湾春茧体育馆进行2017<时间的朋友>跨年演讲,很多网友一直在找直播的地址还是没找到,现在ytkah就第一时间分享一些精彩ppt弥补网友的 ...
- Python微信-- 分享接口(分享到朋友圈、朋友、空间)
生成JS-SDK权限验证的签名 获取signature(签名)首先要获得 1.#获得jsapi_ticket 2.#获取当前页面的url #获取当前页面的url url="{}://{}{} ...
- Apple Watch版微信来了 收发微信刷朋友圈不在话下
昨晚果粉守了一夜的Apple Watch发布会,意料中的惊喜不少,最让人兴奋的是微信成为首批支持的应用.是的,在全球拥有4.68亿月活跃用户的微信怎么可能不第一时间入驻呢?之前我们就有聊过Apple ...
- UC浏览器 分享到朋友圈和微信好友 分类: JavaScript 2015-04-28 14:45 615人阅读 评论(1) 收藏
用手机UC浏览器访问新浪微博,会注意到有这样的两个分享按钮: 在手机端浏览器里,点击分享按钮,就可以启动微信客户端并分享到微信.研究了下其源代码,存在这样的一个js:http://mjs.sinaim ...
- <把时间当做朋友>读书笔记
这本书我早就看过,还想再来一遍 开始这一行动是看李萌在朋友圈晒101计划,每天健身,读书半小时之类的,我也想做点啥,那就每天睡前读书半小时吧,怎么坚持下去呢? 我不想晒到朋友圈里,那就晒给玉玉看吧, ...
- MWeb 2.0 测试版可以下载啦,这次是公开测试,感兴趣的朋友可以试试
2.0 版是 MWeb 发布以来,最重要的一个版本.MWeb 自去年一月份发布以来,获得了很多朋友的建议,在此非常感谢!没有你们,2.0 版可能就不能出来!然后再次感谢 Producter: http ...
- hduoj 1286 找新朋友
http://acm.hdu.edu.cn/showproblem.php?pid=1286 找新朋友 Time Limit: 2000/1000 MS (Java/Others) Memory Li ...
- iOS版微信朋友圈数据库的简要分析
本文版权归cxun所有,如有转载请注明出处与本文链接,谢谢!原文地址:http://www.cnblogs.com/cxun/p/4550523.html 之前写了一些关于微信聊天记录的博文之后,不少 ...
随机推荐
- [模拟赛] GotoAndPlay
GotoAndPlay 10月3日,在杭州市西湖景区,一只小松鼠不停地接受一道道食物,花生. 玉米.饼干,可谓来者不拒,憨态可掬的模样吸引了众多围观者... Description 小松鼠终于吃撑了, ...
- Ubuntu系统iptables规则的查看和清除
系统不支持service iptables restart,service iptables status,如何查看与清除iptable的规则呢? 一 iptables查看基本语法 iptables ...
- ubuntu12.04回归到经典的gnome界面
要想删除Unity恢复到经典Gnome桌面也很简单,几乎就是一条命令的事情--命令这种东西虽然不直观,但非常可靠和快捷,同时按住Ctrl+Alt+T三个键,调出系统终端,输入: sudoapt-get ...
- es6+最佳入门实践(5)
5.对象扩展 5.1.对象简写 在es5中,有这样一种写法 var name = "xiaoqiang"; var age = 12; var obj = { name : nam ...
- classList详解,让你的js方便地操作DOM类
在此之前,jQuery的hasClass.addClass.removeClass我们已经再熟悉不过了,然而我们并不会在每一个项目中都会去使用 jQuery或者Zepto,譬如在移动端的网页中,考虑到 ...
- 关于UML
http://www.cnblogs.com/zfc2201/archive/2011/08/16/2141433.html
- UVa 12265 贩卖土地 单调栈
题意 输入一个\(n\times m\)的矩阵,每个格子可能是空地,也可能是沼泽.对于每个空地格子,求出以它为右下角的空矩形的最大周长,然后统计每个周长出现了多少次. 思路 对于 每一行 每两个沼泽之 ...
- Python学习笔记 - day6 - 函数
函数 函数在编程语言中就是完成特定功能的一个词句组(代码块),这组语句可以作为一个单位使用,并且给它取一个名字.可以通过函数名在程序的不同地方多次执行(这叫函数的调用).函数在编程语言中有基本分为:预 ...
- LeetCode 6:Excel Sheet Column Number
Given a column title as appear in an Excel sheet, return its corresponding column number. For exampl ...
- TCP/IP Http的区别
TPC/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据. 关于TCP/IP和HTTP协议的关系,网络有一段比较容易理解的介绍:“我们在传输数据时,可以 ...