全局最小割 Stoer-Wagner (SW算法)优化

优化吃藕了,感谢放宽时限,感谢平板电视 (pb_ds)

#include <iostream>
#include <cstdio>
#include <cstring>
#include <ext/pb_ds/priority_queue.hpp> typedef long long ll;
typedef __gnu_pbds::priority_queue<std::pair<int, int>, std::less<std::pair<int, int> >, __gnu_pbds::binomial_heap_tag >pq; struct Edge {int from, to, nxt, val;}; const int maxn = 3e3 + ;
const int maxm = 4e5 + ;
const int inf = ;
int n, r;
bool vis[maxn], bin[maxn];
Edge e[maxm * + ];
int head[maxn], id[maxn][maxn], esz; inline ll read() {
int x = , f = ; char ch = getchar();
while(ch < '' || ch > '') {if(ch == '-')f = -; ch = getchar();}
while(ch >= '' && ch <= '') {x = x * + ch - ''; ch = getchar();}
return x * f;
} inline void add_edge(int from, int to, int val) {
if(id[from][to] == -) {
e[esz].from = from, e[esz].to = to, e[esz].val = val, e[esz].nxt = head[from];
id[from][to] = esz; head[from] = esz++;
} else {
e[id[from][to]].val += val;
}
} inline void init() {
memset(bin, false, sizeof(bin));
memset(head, -, sizeof(head));
memset(id, -, sizeof(id));
esz = ;
} pq que;
pq::point_iterator it[maxn];
inline int contract(int &s, int &t) { // Find s,t
memset(vis, false, sizeof(vis));
int i, j, k, mincut, maxc;
while(!que.empty()) que.pop();
for(i = ; i <= n; ++i)
if(!bin[i])it[i] = que.push(std::make_pair(, i));
else it[i] = nullptr;
for(i = ; i <= n; i++) {
k = -; maxc = -;
if(que.empty()) return mincut;
k = que.top().second, maxc = que.top().first; que.pop();
s = t; t = k; mincut = maxc; vis[k] = true;
for(j = head[k]; ~j; j = e[j].nxt) {
int v = e[j].to, w = e[j].val;
if(!bin[v] && !vis[v]) {
que.modify(it[v], std::make_pair((it[v]->first) + w, v));
}
}
}
return mincut;
} inline int Stoer_Wagner() {
int mincut, i, j, s, t, ans;
for(mincut = inf, i = ; i < n; i++) {
ans = contract(s, t);
bin[t] = true;
if(mincut > ans) mincut = ans;
if(mincut == )return ;
for(j = ; j <= n; j++) if(!bin[j]) {
if(id[j][t] == -)continue;
if(id[s][j] == -)add_edge(s, j, e[id[j][t]].val);
else e[id[s][j]].val += e[id[j][t]].val;
if(id[j][s] == -)add_edge(j, s, e[id[j][t]].val);
else e[id[j][s]].val += e[id[j][t]].val;
}
}
return mincut;
} int main() {
int m;
while(scanf("%d%d", &n, &m) != -) {
init();
for(int i = ; i <= m; i++) {
int a, b, c;
a = read(), b = read(), c = read();
add_edge(a, b, c); add_edge(b, a, c);
}
printf("%d\n", Stoer_Wagner());
}
return ;
}

2017"百度之星"程序设计大赛 - 资格赛 1002 度度熊的王国战略的更多相关文章

  1. hdu 6082 度度熊与邪恶大魔王(2017"百度之星"程序设计大赛 - 资格赛 )

    度度熊与邪恶大魔王 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  2. 2017"百度之星"程序设计大赛 - 资格赛【1001 Floyd求最小环 1002 歪解(并查集),1003 完全背包 1004 01背包 1005 打表找规律+卡特兰数】

    度度熊保护村庄 Accepts: 13 Submissions: 488 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/3276 ...

  3. [SinGuLaRiTy] 2017 百度之星程序设计大赛-资格赛

    [SinGuLaRiTy-1034] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. 度度熊保护村庄  Time Limit: 2000/10 ...

  4. 2017"百度之星"程序设计大赛 - 资格赛

    度度熊与邪恶大魔王  Accepts: 3666  Submissions: 22474  Time Limit: 2000/1000 MS (Java/Others)  Memory Limit: ...

  5. 2014年百度之星程序设计大赛 - 资格赛 1002 Disk Schedule(双调欧几里得旅行商问题)

    Problem Description 有非常多从磁盘读取数据的需求,包含顺序读取.随机读取.为了提高效率,须要人为安排磁盘读取.然而,在现实中,这样的做法非常复杂.我们考虑一个相对简单的场景.磁盘有 ...

  6. 2017"百度之星"程序设计大赛 - 资格赛-度度熊与邪恶大魔王(dp+后缀最小值)

    度度熊与邪恶大魔王 思路:由于防御和血量的范围很小,所以暴力枚举出对于每种防御造成的每种伤害所需的最小花费,最后只需在伤害大于等于血量的情况下再找到最小花费(这个只需要后缀最小值预处理一下就可以了) ...

  7. 2018"百度之星"程序设计大赛 - 资格赛 1002 子串查询

    题面又是万能的毒毒熊... 实在不想写了,就只写了这题 记26个前缀和查询枚举最小值直接算 实在是氵的死 而且我忘记输出Case #%d 想了很久 >_< #include<bits ...

  8. 2017"百度之星"程序设计大赛 - 资格赛 寻找母串

    Problem Description 对于一个串S,当它同时满足如下条件时,它就是一个01偏串: 1.只由0和1两种符组成: 2.在S的每一个前缀中,0的个数不超过1的个数: 3.S中0的个数和1的 ...

  9. 2017"百度之星"程序设计大赛 - 资格赛 度度熊的王国战略

    度度熊的王国战略 度度熊国王率领着喵哈哈族的勇士,准备进攻哗啦啦族. 哗啦啦族是一个强悍的民族,里面有充满智慧的谋士,拥有无穷力量的战士. 所以这一场战争,将会十分艰难. 为了更好的进攻哗啦啦族,度度 ...

随机推荐

  1. [Codevs] 矩形面积求并

    http://codevs.cn/problem/3044/ 线段树扫描线矩形面积求并 基本思路就是将每个矩形的长(平行于x轴的边)投影到线段树上 下边+1,上边-1: 然后根据线段树的权值和与相邻两 ...

  2. CMake学习- 使用批处理设置编译环境

    批处理-.bat cd /d "%~dp0" mkdir build mkdir install cd build ..\cmake37\bin\cmake.exe -D WIN3 ...

  3. Spring Cloud Eureka(六):Eureka Client 如何注册到Eureka Server

    1.本节概要 根据前文我们对Eureka Server 有了一定的了解,本节我们主要学习Eureka Client 与 Eureka Server 如何通讯的及相关通信机制是什么,本文会弄清楚一下几个 ...

  4. 图论——最小生成树:Prim算法及优化、Kruskal算法,及时间复杂度比较

    最小生成树: 一个有 n 个结点的连通图的生成树是原图的极小连通子图,且包含原图中的所有 n 个结点,并且有保持图连通的最少的边.简单来说就是有且仅有n个点n-1条边的连通图. 而最小生成树就是最小权 ...

  5. python+socket+jq实现web页面实时输出结果

    例如有这样一个需求: 在终端上进行ping操作,现在想把这个这个操作放到web页面上进行,并且实现实时输出的效果. 来分析下具体实现过程 第一步,传统的http请求实现这个有点不太友好,因为这里边是一 ...

  6. adb的一些命令

    adb pull <手机路径> <本机路径> 从手机中拉取信息到本地电脑上 adb push <本机路径> <手机路径> 从本地电脑推送信息到手机上

  7. IDEA 重复代码快速重构(抽取重复代码快捷键)

    Ctrl+Alt+M 顺带一提,eclipse的快捷键是:Alt+Shift+M;

  8. mysql 给用户设置权限

    grant   all   on   wordpress.*   to  wordpress@'10.0.0.%'  identified  by  'wordpress'; all    全部权限 ...

  9. [java]察看两个日期间差多少秒/小时/天

    Java 中Date类getTime()的方法返回从1970-1-1以来的毫秒数,这是下面函数运行的基础. package com.example.demo; import java.text.Par ...

  10. v-if与v-show的区别?

    v-if的显示和隐藏实在dom里创建和消除dom节点 v-show是用css样式的display来控制dom节点的显示和隐藏 相比之下,v-show 就简单得多——不管初始条件是什么,元素总是会被渲染 ...