是毒瘤的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]朋友的更多相关文章

  1. QQ空间/朋友圈类界面的搭建

    类似于QQ空间的布局主要是在说说信息.点赞.回复三大部分的自适应布局上. 当我们需要搭建类似QQ空间.微信朋友圈的界面的时候,可做如下操作: 创建一个对应的model类: 创建一个对应model类的f ...

  2. 2017《时间的朋友》罗振宇跨年演讲ppt

    2016年12月31日晚,罗辑思维的罗振宇将在深圳湾春茧体育馆进行2017<时间的朋友>跨年演讲,很多网友一直在找直播的地址还是没找到,现在ytkah就第一时间分享一些精彩ppt弥补网友的 ...

  3. Python微信-- 分享接口(分享到朋友圈、朋友、空间)

    生成JS-SDK权限验证的签名 获取signature(签名)首先要获得 1.#获得jsapi_ticket 2.#获取当前页面的url #获取当前页面的url url="{}://{}{} ...

  4. Apple Watch版微信来了 收发微信刷朋友圈不在话下

    昨晚果粉守了一夜的Apple Watch发布会,意料中的惊喜不少,最让人兴奋的是微信成为首批支持的应用.是的,在全球拥有4.68亿月活跃用户的微信怎么可能不第一时间入驻呢?之前我们就有聊过Apple ...

  5. UC浏览器 分享到朋友圈和微信好友 分类: JavaScript 2015-04-28 14:45 615人阅读 评论(1) 收藏

    用手机UC浏览器访问新浪微博,会注意到有这样的两个分享按钮: 在手机端浏览器里,点击分享按钮,就可以启动微信客户端并分享到微信.研究了下其源代码,存在这样的一个js:http://mjs.sinaim ...

  6. <把时间当做朋友>读书笔记

    这本书我早就看过,还想再来一遍 开始这一行动是看李萌在朋友圈晒101计划,每天健身,读书半小时之类的,我也想做点啥,那就每天睡前读书半小时吧,怎么坚持下去呢? 我不想晒到朋友圈里,那就晒给玉玉看吧, ...

  7. MWeb 2.0 测试版可以下载啦,这次是公开测试,感兴趣的朋友可以试试

    2.0 版是 MWeb 发布以来,最重要的一个版本.MWeb 自去年一月份发布以来,获得了很多朋友的建议,在此非常感谢!没有你们,2.0 版可能就不能出来!然后再次感谢 Producter: http ...

  8. hduoj 1286 找新朋友

    http://acm.hdu.edu.cn/showproblem.php?pid=1286 找新朋友 Time Limit: 2000/1000 MS (Java/Others) Memory Li ...

  9. iOS版微信朋友圈数据库的简要分析

    本文版权归cxun所有,如有转载请注明出处与本文链接,谢谢!原文地址:http://www.cnblogs.com/cxun/p/4550523.html 之前写了一些关于微信聊天记录的博文之后,不少 ...

随机推荐

  1. JavaScript的大括号的语义

    Javascript中大括号"{}"有四种语义作用: 语义1. 组织复合语句,这是最常见的: view source   print? 1 if( condition ) { 2 ...

  2. MySQL:BlackHole

    MySQL:BlackHole 顾名思义BlackHole就是黑洞,只有写入没有输出.现在就来实验一下吧 首先查看一下MySQL支持的存储引擎 mysql> show engines;+---- ...

  3. MySQL DELAY_KEY_WRITE Option

    delay_key_write   This option applies only to MyISAM tables. It can have one of the following values ...

  4. mysql删除id最小的条目

    DELETE FROM 表1 WHERE Mid in (select Mid from (SELECT Min(Mid) Mid FROM 表1 c1) t1);

  5. 游戏中的过程生成——元胞自动机 Celluar Automata 生成洞穴地形

    最近在学习过程生成技术,在这里写一些心得. 对于元胞自动机,我们这里只讨论输入是一副二维bool数组的情况,即大多数游戏中的情况. 一个元胞自动机,对于一个输入,给出一个同样格式的输出.输出中的每个点 ...

  6. 人脸识别 - 环境搭建(Ubuntu 16.04)

    安装人脸识别开源库(face_recognition) pip3 install face_recognition 注意:pip3 尝试编译 dlib 依赖时很可能会报错,参考:https://www ...

  7. mysql五-1:单表查询

    一 介绍 本节内容: 查询语法 关键字的执行优先级 简单查询 单条件查询:WHERE 分组查询:GROUP BY HAVING 查询排序:ORDER BY 限制查询的记录数:LIMIT 使用聚合函数查 ...

  8. Linux IO 同步/异步 阻塞/非阻塞

    同步IO:导致请求进程阻塞,直到IO操作完成: 是内核通知我们何时进行启动IO操作,而实际的IO操作需要当前进程本身阻塞完成: 包括:阻塞式IO模型,非阻塞式IO模型,IO复用模型,信号驱动式IO模型 ...

  9. locust===Writing a locustfile

    The Locust class A locust class represents one user (or a swarming locust if you will). Locust will ...

  10. Linux执行shell脚本方式及区别&命令后台运行

    Linux执行shell脚本方式及区别&命令后台运行 http://blog.csdn.net/heqiyu34/article/details/19089951/