[Luogu 3701] 「伪模板」主席树

<题目链接>


这是一道网络流,不是主席树,不是什么数据结构,而是网络流。

题目背景及描述都非常的暴力,以至于 Capella 在做此题的过程中不禁感到生命流逝。

S 向 byx 的树中的每一个人连有向边,手气君的树中的每一个人向 T 连有向边,边权为这个人的寿命。统计同一棵树中的膜法师数量 x。如果一个人是主席,那么边权要加上 x。(续得好啊)

然后,如果 byx 树中的一个点 i 能赢手气君树中的点 j,那么连 i->j,边权为 1。

跑最大流,最终答案为 min(m,ans)。

PS:指针邻接表写网络流真有意思,我再也不用写什么 ((i-1)^1)+1 蛇皮操作了!开心!

以及悄悄在代码里表白一下 Procyon。qwqqwqqwq

#include <algorithm>
#include <cstdio>
#include <cstring>
#include <queue>
using std::min;
using std::queue;
const int MAXN=210,INF=0x3f3f3f3f;
int n,m,S,T,win[5][5]={ {0 ,1 ,1 ,-1 ,-1 },
{-1 ,0 ,1 ,1 ,-1 },
{-1 ,-1 ,0 ,1 ,1 },
{1 ,-1 ,-1 ,0 ,1 },
{1 ,1 ,-1 ,-1 ,0 }};
struct Edge
{
int to,w;
Edge *nxt,*back;
Edge(int to=0,int w=0,Edge* nxt=nullptr):to(to),w(w),nxt(nxt),back(nullptr){}
~Edge(void)
{
if(nxt!=nullptr)
delete nxt;
}
}*head[MAXN];
void AddEdges(int u,int v,int w)
{
head[u]=new Edge(v,w,head[u]);
head[v]=new Edge(u,0,head[v]);
head[u]->back=head[v];
head[v]->back=head[u];
}
int Number(char *s)
{
if(s[0]=='J')
return 0;
else if(s[0]=='H')
return 1;
else if(s[0]=='W')
return 2;
else if(s[0]=='E')
return 3;
else if(s[0]=='Y')
return 4;
}
void InitTree(int *a)
{
char s[5];
for(int i=1;i<=n;++i)
{
scanf(" %s",s);
a[i]=Number(s);
if(a[i]==4)
++a[0];
}
}
void Init(void)
{
static int a[MAXN],b[MAXN];
T=(n<<1)+1;
InitTree(a);
InitTree(b);
for(int i=1;i<=n;++i)
head[i]=nullptr;
for(int i=1,x;i<=n;++i)
{
scanf("%d",&x);
AddEdges(S,i,!a[i] ? x+a[0] : x);
}
for(int i=1,x;i<=n;++i)
{
scanf("%d",&x);
AddEdges(i+n,T,!b[i] ? x+b[0] : x);
}
for(int i=1;i<=n;++i)
for(int j=1;j<=n;++j)
if(win[a[i]][b[j]]==1)
AddEdges(i,j+n,1);
}
void Destroy(void)
{
for(int i=S;i^T;++i)
delete head[i];
}
namespace Procyon
{
int dis[MAXN];
Edge *cur[MAXN];
bool BFS(int S,int T)
{
queue<int> q;
memset(dis,0,sizeof dis);
q.push(S);
dis[S]=1;
while(!q.empty())
{
int u=q.front(),v;
q.pop();
for(Edge *i=head[u];i!=nullptr;i=i->nxt)
if(i->w && !dis[v=i->to])
{
q.push(v);
dis[v]=dis[u]+1;
}
}
return dis[T];
}
int DFS(int u,int k)
{
if(u==T || !k)
return k;
int v,f,sum=0;
for(Edge *&i=cur[u];i!=nullptr;i=i->nxt)
if(i->w && dis[v=i->to]==dis[u]+1 && (f=DFS(v,min(k,i->w))))
{
k-=f;
sum+=f;
i->w-=f;
i->back->w+=f;
}
if(!sum)
dis[u]=1;
return sum;
}
void Dinic(int S,int T)
{
int ans=0;
while(BFS(S,T))
{
memcpy(cur,head,sizeof head);
ans+=DFS(S,INF);
}
printf("%d\n",min(m,ans));
}
}
int main(int argc,char** argv)
{
scanf("%d %d",&n,&m);
Init();
Procyon::Dinic(S,T);
Destroy();
return 0;
}

谢谢阅读。

[Luogu 3701] 「伪模板」主席树的更多相关文章

  1. [Luogu] P3701 「伪模板」主席树

    题目背景 byx和手气君都非常都非常喜欢种树.有一天,他们得到了两颗奇怪的树种,于是各自取了一颗回家种树,并约定几年后比一比谁种出来的树更加牛x. 题目描述 很快,这棵树就开花结果了.byx和手气君惊 ...

  2. P3701 「伪模板」主席树

    题目背景 byx和手气君都非常都非常喜欢种树.有一天,他们得到了两颗奇怪的树种,于是各自取了一颗回家种树,并约定几年后比一比谁种出来的树更加牛x. 题目描述 很快,这棵树就开花结果了.byx和手气君惊 ...

  3. 【luoguP3701】「伪模板」主席树

    description byx和诗乃酱都非常都非常喜欢种树.有一天,他们得到了两颗奇怪的树种,于是各自取了一颗回家种树,并约定几年后比一比谁种出来的树更加牛x. 很快,这棵树就开花结果了.byx和诗乃 ...

  4. LuoguP3701 「伪模板」主席树

    题面 这个题很有意思啊... 其实是道最大流板子题,只连byx会赢的边,S向byx连,另一个连T... 注意有长者时连的边加上同方mogician的个数... 还要注意mogician可以无限续命,也 ...

  5. [洛谷P3701]「伪模板」主席树

    题目大意:太暴力了,就不写了,看这儿 题解:对于每个$byx$的人,从源点向人连边,容量为此人的寿命. 对于每个手气君的人,从人向汇点连边,容量为此人的寿命. 对于每个$byx$的人与手气君的人,如果 ...

  6. 「模板」 线段树——区间乘 && 区间加 && 区间求和

    「模板」 线段树--区间乘 && 区间加 && 区间求和 原来的代码太恶心了,重贴一遍. #include <cstdio> int n,m; long l ...

  7. 「WC 2019」数树

    「WC 2019」数树 一道涨姿势的EGF好题,官方题解我并没有完全看懂,尝试用指数型生成函数和组合意义的角度推了一波.考场上只得了 44 分也暴露了我在数数的一些基本套路上的不足,后面的 \(\ex ...

  8. 【题解】#6622. 「THUPC 2019」找树 / findtree(Matrix Tree+FWT)

    [题解]#6622. 「THUPC 2019」找树 / findtree(Matrix Tree+FWT) 之前做这道题不理解,有一点走火入魔了,甚至想要一本近世代数来看,然后通过人类智慧思考后发现, ...

  9. 【Luogu】P3384主席树模板(主席树查询K小数)

    YEAH!我也是一个AC主席树模板的人了! 其实是个半吊子 我将尽量详细的讲出我的想法. 主席树太难,我们先搞普通线段树好了 普通线段树怎么做?我的想法是查询K次最小值,每次查完把查的数改成INF,查 ...

随机推荐

  1. 《javascript模式--by Stoyan Stefanov》书摘--汇总

    <javascript模式--by Stoyan Stefanov>书摘--基本技巧 http://www.cnblogs.com/liubei/p/JavascriptModeLog1. ...

  2. 关于docker 基础使用记录

    Docker Hub地址:https://hub.docker.com Docker Hub 存放着 Docker 及其组件的所有资源.Docker Hub 可以帮助你与同事之间协作,并获得功能完整的 ...

  3. 软件功能-东北师大站-第三次作业(PSP)

    1.本周PSP 2.本周进度条 3.本周累计进度图 代码累计折线图 博文字数累计折线图 本周PSP饼状图

  4. UVALive - 6868 Facility Locations 想法题

    题目链接: http://acm.hust.edu.cn/vjudge/problem/88634 Facility Locations Time Limit: 3000MS 题意 给你一个m*n的矩 ...

  5. Mac OS安装Scrapy失败

    报错: DEPRECATION: Uninstalling a distutils installed project (six) has been deprecated and will be re ...

  6. LintCode-54.转换字符串到整数

    转换字符串到整数 实现atoi这个函数,将一个字符串转换为整数.如果没有合法的整数,返回0.如果整数超出了32位整数的范围,返回INT_MAX(2147483647)如果是正整数,或者INT_MIN( ...

  7. JAVA的中文字符乱码问题

    来源:http://luzefengoo.blog.163.com/blog/static/1403593882012754428536/ JAVA的中文字符乱码问题一直很让人头疼.特别是在WEB应用 ...

  8. BZOJ4832 抵制克苏恩(概率期望+动态规划)

    注意到A+B+C很小,容易想到设f[i][A][B][C]为第i次攻击后有A个血量为1.B个血量为2.C个血量为3的期望伤害,倒推暴力转移即可. #include<iostream> #i ...

  9. [AHOI2009]最小割 最小割可行边&必须边

    ~~~题面~~~ 题解: 做这题的时候才知道有最小割可行边和必须边这种东西..... 1,最小割可行边, 意思就是最小割中可能出现的边. 充要条件: 1,满流 2,在残余网络中找不到x ---> ...

  10. BZOJ3140:[HNOI2013]消毒——题解

    http://www.lydsy.com/JudgeOnline/problem.php?id=3140 https://www.luogu.org/problemnew/show/P3231 最近在 ...