首页 > 其他分享 >12.9闲话

12.9闲话

时间:2023-12-09 19:12:00浏览次数:44  
标签:head ver int 闲话 .... tot edge 12.9

奋战冬三月昨日跑操排名

第一名...第二名....第三名....倒第一....到第二....到第三....

奋战冬三月昨日扣分明细

xx班有人掉队扣30分

xx班有人拒报学号扣30分

....

好各班,操前班呼!

一班,跑步,走!

2班跟上!

....

9班和十班的班距缩小!!

十一班十二班缩小班距!跟上!

13班口号声音很响!
....

20班留下检查人数,检查完来国旗下集合

各班体委跑操后来国旗下集合,我们开个短会

...

出口处不要走!跑步进入班级,哪个班级走,我们不记学号,只记班级直接扣30分,让他们班倒第一!

....

加权的班级记得加权!哪个班级不加直接扣20分!

学生会记得检查

放音乐的同学音乐停一下

最大流

  • Edmond_Karp 增广路

下面简称EK

若一条从源点\(S\)到汇点\(T\)的路径上各条边的剩余容量为\(0\),则称这条路径是一条增广路

显然可以让流沿着增广路从\(S\)流到\(T\)使网络流量增大

EK的算法思想就是BFS寻找增广路,直到网络上不存在增广路为止

在每轮寻找增广路时EK只考虑图中所有\(f(x,y) < c(x,y)\) 的边并用BFS寻找到一条\(S\)到\(T\)的包含边数最少的路径并记录路径上各边的剩余容量的最小值\(m\),则网络的流量可以增加\(m\)

当一条边的流量\(f(x,y)>0\)时它的反向边\(f(y,x) < c(y,x)\)所以EK还需要遍历\(E\)中每条边的反向边

时间复杂度\(O(nm^2)\)

看的我直接暴毙了

然后去查发现能优化


将 \(G\) 中所有结点和剩余容量大于 \(0\) 的边构成的子图称为残量网络 \(G_f\) ,即 \(G_f=(V,E_f)\) ,其中 \(E_f=\left\{(u,v) \mid c_f(u,v)>0\right\}\)。

然后EK每轮都可能会遍历整个参量网络,但只找出一条增广路,给我看恼了

  • Dinic

    • 前言:

      没看太懂,完全瞎写的,毫无参考价值

首先在BFS中有一个节点的层次\(d[x]\)代表从\(S\)到\(x\)的最少要经过的边数

在残量网络中满足\(d[y]=d[x]+1\)的边\((x,y)\)构成的子图称作分层图

分层图明显是一个DAG然后就可以重复以下几个操作

  • 在残量网络中BFS求出节点的层次构造分层图

  • 在分层图里DFS寻找增广路在回溯时实时更新剩余容量

  • 重复以上操作直到残量网络中\(S\)无法到达\(T\)

K8的学习笔记摘录以下

  • 无用点优化

    如果有流量流向一个点的时候这个点流不动了,说明它在当前分层图上不再能做出贡献,可以暂时删去。

  • 当前弧优化

    决定复杂度,不会负优化,你慢了说明你挂了。

    如果当前到点 \(u\) 的流在 \(u\) 遍历完其指向的所有点时用完了,我们记录一下是推向哪条边时用完的,下次再搜索到 \(u\) 时直接从这条边开始推,因为之前的肯定推满了。

然后就是复杂度\(O(n^2m)\),但是一般远远达不到这个上界

代码(不知道是不是对的)
#include<bits/stdc++.h>
#define int long long
const int INF = 0x66CCFF0712;
const int MAXM = 0X66CCFF;
const int MAXN = 0X6CF;
const int maxm = 50010;
namespace IO{
    inline void close(){std::ios::sync_with_stdio(false);std::cin.tie(0);std::cout.tie(0);}
    inline void Fire(){freopen(".in","r",stdin);freopen(".out","w",stdout);}
    inline int read(){int s = 0,w = 1;char ch = getchar();while(ch<'0'||ch>'9'){ if(ch == '-') w = -1;ch = getchar();}while(ch>='0'&&ch<='9'){ s = s*10+ch-'0';ch = getchar();}return s*w;}
    inline void write(int x){char F[200];int tmp=x>0?x:-x,cnt=0;;if(x<0)putchar('-') ;while(tmp>0){F[cnt++]=tmp%10+'0';tmp/=10;}if(cnt==0)putchar('0');while(cnt>0)putchar(F[--cnt]);}
}
using namespace IO;
struct graph{
    int ver,edge,Next;
}T[MAXM];
int head[MAXM],d[maxm],now[maxm],n,m,s,t,tot,max;
std::queue<int> q;
namespace Graph{
    void add(int x,int y,int z){
        T[++tot].ver = y;
        T[tot].edge = z;
        T[tot].Next = head[x];
        head[x] = tot;

        T[++tot].ver = x;
        T[tot].edge = 0;
        T[tot].Next = head[y];
        head[y] = tot;
    }
    inline bool bfs(){
        memset(d,0,sizeof(d));
        while(q.size()) q.pop();
        q.push(s);d[s]=1;now[s]=head[s];
        while(q.size()){
            int x = q.front();q.pop();
            for(int i=head[x] ; i ; i=T[i].Next)
                if(T[i].edge && !d[T[i].ver]){
                    q.push(T[i].ver);
                    now[T[i].ver] = head[T[i].ver];
                    d[T[i].ver] = d[x]+1;
                    if(T[i].ver == t)return 1;
                }
        } 
        return 0;
    }
    inline int dinic(int x,int flow){
        if(x == t) return flow;
        int rest = flow,k;
        for(int i=now[x] ; i&&rest ; i=T[i].Next){
            now[x] = i;
            if(T[i].edge && d[T[i].ver]==d[x]+1){
                k = dinic(T[i].ver,std::min(rest,T[i].edge));
                if(!k) d[T[i].ver]=0;
                T[i].edge -= k;
                T[i^1].edge += k;
                rest -= k;
            }
        }
        return flow-rest;
    }
}
signed main(){
    n=read(),m=read(),s=read(),t=read();
    tot=1;
    for(int i=1;i<=m;i++) Graph::add(read(),read(),read());
    int flow=0;
    while(Graph::bfs())
        while(flow=Graph::dinic(s,INF))
            max+=flow;
    write(max);
}

二分图最大匹配

最喜欢的一集

将源点\(S\)连上左边所有点,右边所有点连上汇点\(T\),容量皆为 \(1\) 。原来的每条边从左往右连边,容量也皆为 \(1\) ,最大流即最大匹配

借用一下大佬的博客的图

我们把有流流过看作是选择这条边,没有流流过看作不选这条边,每条边的边权全都是\(1\),因此流过一条边就有\(1\)的流量,答案就是有多少条边被选择

因为求的是最大流,所以满足有最多边被选择,得到的就是最大匹配

虽然网络流的每个节点都可以有流往不同边流,而二分图的最大匹配每个节点只能有一条边相连

但是每条边的容量都是\(1\),所以一旦有流流过这条边就满流了,以后的流也不会往这里流了,所以得到的是正确的答案

标签:head,ver,int,闲话,....,tot,edge,12.9
From: https://www.cnblogs.com/LuoTianYi66ccff/p/17891336.html

相关文章

  • 模拟套题 12.9
    不敢想象这是曾经初二的人做的T1非皇后大意:给定\(R\)行\(C\)列的棋盘你可以随便在一个格子放一个非皇后要求不能走直线和对角线走\(M\)步将走过的格子按顺序记起来求最终有多少种不同排列Solutiondp裸题定义\(f_{i,j,k}\)为走了\(i\)次,到格子\((j,k)\)......
  • 12.9 蓝桥杯 huffuman树c语言
    今天学习了蓝桥杯的huffuman树,总结如下:问题描述Huffman树在编码中有着广泛的应用。在这里,我们只关心Huffman树的构造过程。给出一列数{pi}={p0,p1,…,pn-1},用这列数构造Huffman树的过程如下:1.找到{pi}中最小的两个数,设为pa和pb,将pa和pb从{pi}中删除掉,然后将它们的和加......
  • 闲话12.8
    颓。上午把物理样卷2做了,AK了。然后看了一个小时生物就润去考生物了,没啥感觉,不会的也不多,勉强能上90pts?发现lyt的准考证上写的班级是B20......
  • 12.8 闲话
    K8这几天不在,原来是每天写3000道题,从一个连深搜都写的对的dalao成长为NOIAKer,创造了NOIP一百九十多省选600分的奇迹,这几天不在已经刷了24000道了我去今天我怎么疯狂被JC,错了哥原来\(K8\)说的二分图不重要说的是可以用网络流代替「重要提醒」:学过网络流后你会发现这玩意很不重......
  • 【闲话】机房绿萝培养笔记(持续更新中)
    2023.12.7:第一次考虑照顾机房的绿萝。所以它们没人浇水没有光照叶子黄了一堆也没剪是怎么活到现在的啊(下午休息时间不是很够,先剪了一半黄叶,剩下的第二天剪。之后找个学校里合适的地方,中午把绿萝抱出去晒太阳吧(?)查了一下,有的绿萝叶片上有白色斑纹,是正常现象,但如果长时间缺阳光就......
  • 闲话12.7
    颓。上午写物理样卷,94pts,算动能的时候少乘\(\frac{1}{2}\)痛失3pts。然后去考傻逼地理了,和APJ感受差不多,妈的什么傻逼地理我草。场上略微估算了下自己不确定的题的分数,大约有20pts,输!准备三战,大不了B就B吧,妈的。下午学OI。写了写流。网络流题和题之间差别这么大,为啥......
  • 12.7闲话2
    HutaoImpact:我去,这不V正弦ger_洛天依吗HutaoImpact:我今天必须想个办法发烧回去抽银狼HutaoImpact:我去我怎么还不走我马上退烧了HutaoImpact:我给自己挂个冰元素弱点然后冻一晚上就能回家了HutaoImpact:凭什么不让我拿,就凭这东西是你的?HutaoImpact:我把机房那个窗户把手拆下来之......
  • 12.7闲话
    今天一看那个高中楼都被围起来了,估计快学考了为啥和同学打招呼都没人理我,哦原来因为我是菜√,太菜了导致的推歌虚拟歌手贺岁纪《万物有灵》歌词似一捧细泉的奔逃跃过石缝岩角降落到我怀抱待天地再静默一秒这蓬勃的心跳就将划开晨晓我是亿万株花草破土时的微渺渴盼你......
  • 闲话12.6
    换了一个拉格兰头像。做了做化学生物的样卷,生物样卷91pts,化学样卷95pts,赢!物理明天再做......
  • 2023-12-05 闲话 收收手,写写字
    因为摆烂既不想做厂子笔试题,也不想学Rust,也不想做AGC了,那么随便写点东西记录一下之前的生活啊。今天是我们亲爱的杨卓凡同学的最后一天未成年生活了。提前祝他成年快乐,上个月我去白净的时候他问我要不要12-6去,但是我明天上午11点有一个面试,后天下午可能同时约了两个笔试,......