题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6582

题意:删掉边使得1到n的最短路改变,删掉边的代价为该边的边权。求最小代价。

比赛时一片浆糊,赛后听到dinic瞬间思维通透XD

大致做法就是先跑一遍最短路,然后再保留所有满足dis[i]+w==dis[j]的边,在这些边上跑最小割(dinic)。

代码写的异常丑陋,见谅QAQ

 #include<iostream>
#include<cstdio>
#include<cstdlib>
#include<algorithm>
#include<cstring>
#include<string>
#include<queue>
using namespace std;
typedef long long ll;
const ll maxn = 3e5 + ;
const ll inf = 1e18;
struct node {
ll s, e, next;
ll w;
}edge[maxn * ], edge2[maxn * ];
ll head[maxn], head2[maxn], len, len2;
void init() {
memset(head, -, sizeof(head));
memset(head2, -, sizeof(head2));
len = len2 = ;
}
void add(ll s, ll e, ll w) {
edge[len].s = s;
edge[len].e = e;
edge[len].w = w;
edge[len].next = head[s];
head[s] = len++;
}
void add2(ll s, ll e, ll w) {
edge2[len2].s = s;
edge2[len2].e = e;
edge2[len2].w = w;
edge2[len2].next = head2[s];
head2[s] = len2++;
}
struct p {
ll dis, num;
bool operator<(const p&a)const {
return a.dis < dis;
}
};
ll dis[maxn];
ll vis[maxn];
void dij(ll n) {
priority_queue<p>q;
for (ll i = ; i <= n; i++)
dis[i] = inf, vis[i] = ;
q.push({ 0ll,1ll });
dis[] = 0ll;
while (!q.empty()) {
ll x = q.top().num;
q.pop();
if (vis[x])
continue;
vis[x] = ;
for (ll i = head[x]; i != -; i = edge[i].next) {
ll y = edge[i].e;
if (dis[y] > dis[x] + edge[i].w) {
dis[y] = dis[x] + edge[i].w;
q.push({ dis[y],y });
}
}
}
}
ll d[maxn];
bool bfs(ll s, ll t) {
queue<ll>q;
memset(d, , sizeof(d));
d[s] = 1ll;
q.push(s);
while (!q.empty()) {
ll x = q.front(); q.pop();
for (ll i = head2[x]; i != -; i = edge2[i].next) {
ll y = edge2[i].e;
if (edge2[i].w && !d[y]) {
d[y] = d[x] + 1ll;
q.push(y);
}
}
}
return d[t];
}
ll dfs(ll x, ll t, ll limit) {
if (x == t)
return limit;
ll add, ans = ;
for (ll i = head2[x]; i != -; i = edge2[i].next) {
ll y = edge2[i].e;
if (d[y] == d[x] + && edge2[i].w) {
add = dfs(y, t, min(limit, edge2[i].w));
edge2[i].w -= add;
edge2[i ^ ].w += add;
ans += add;
limit -= add;
if (!limit)
break;
}
}
if (!ans)
d[x] = -;
return ans;
}
ll dinic(ll s, ll t) {
ll ans = ;
while (bfs(s, t))
ans += dfs(s, t, inf);
return ans;
}
int main() {
ll t;
scanf("%lld", &t);
while (t--) {
ll n, m;
init();
scanf("%lld%lld", &n, &m);
ll x, y, z;
for (ll i = ; i <= m; i++) {
scanf("%lld%lld%lld", &x, &y, &z);
add(x, y, z);
}
dij(n);
for (ll i = ; i <= n; i++)
for (ll j = head[i]; j != -; j = edge[j].next)
if (dis[edge[j].s] + edge[j].w == dis[edge[j].e])
add2(edge[j].s, edge[j].e, edge[j].w), add2(edge[j].e, edge[j].s, 0ll);
printf("%lld\n", dinic(, n));
}
return ;
}

[2019杭电多校第一场][hdu6582]Path(最短路&&最小割)的更多相关文章

  1. 2019杭电多校第一场hdu6581 Vacation

    Vacation 题目传送门 update(O(n)) 看了那个O(n)的方法,感觉自己想的那个O(nlogn)的好傻,awsl. 0车最终通过停车线的时候,状态一定是某个车堵住后面的所有车(这个车也 ...

  2. [2019杭电多校第一场][hdu6583]Typewriter(后缀自动机&&dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6583 大致题意是说可以花费p在字符串后添加一个任意字符,或者花费q在字符串后添加一个当前字符串的子串. ...

  3. [2019杭电多校第一场][hdu6579]Operation(线性基)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6579 题目大意是两个操作,1个是求[l,r]区间子序列的最大异或和,另一个是在最后面添加一个数. 如果 ...

  4. [2019杭电多校第一场][hdu6578]Blank(dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6578 计数问题想到dp不过分吧... dp[i][j][k][w]为第1-i位置中4个数最后一次出现的 ...

  5. 2019杭电多校第一场hdu6579 Operation(线性基)

    Operation 题目传送门 解题思路 把右边的数尽量往高位放,构造线性基的时候同时记录其在原序列中的位置,在可以插入的时候如果那个位置上存在的数字的位置比新放入的要小,就把旧的往后挤.用这种发现构 ...

  6. 2018 Multi-University Training Contest 1 杭电多校第一场

    抱着可能杭电的多校1比牛客的多校1更恐怖的想法 看到三道签到题 幸福的都快哭出来了好吗 1001  Maximum Multiple(hdoj 6298) 链接:http://acm.hdu.edu. ...

  7. 2019年杭电多校第一场 1009题String(HDU6586+模拟+单调栈)

    题目链接 传送门 题意 给你一个字符串,要你构造一个长为\(k\)的子串使得每个字母出现的次数在\([L_i,R_i](0\leq i\leq26)\)间且字典序最小. 思路 做这种题目就是要保持思路 ...

  8. 2019年杭电多校第一场 1004题Vacation(HDU6581+数学)

    题目链接 传送门 题意 有\(n+1\)辆车要过红绿灯,告诉你车的长度.与红绿灯的起点(题目假设红绿灯始终为绿).车的最大速度,问你第\(0\)辆车(距离最远)车头到达红绿灯起点的时间是多少(每辆车最 ...

  9. 2019年杭电多校第一场 1002题Operation(HDU6579+线性基)

    题目链接 传送门 题意 初始时有\(n\)个数,现在有\(q\)次操作: 查询\([l,r]\)内选择一些数使得异或和最大: 在末尾加入一个数. 题目强制在线. 思路 对于\(i\)我们记录\([1, ...

随机推荐

  1. HDU1305 Immediate Decodability (字典树

    Immediate Decodability An encoding of a set of symbols is said to be immediately decodable if no cod ...

  2. ZOJ 2314 (无源汇有上下边界的可行流)

    (点击此处查看原题) 题意分析 给出n个结点,m条管道,每条管道存在最小流量和最大流量,而且每个结点的流入量等于流出流出量,问这n个结点和m条管道能否形成流量循环 解题思路 经典的无源汇有上下边界的可 ...

  3. IOS订阅优惠-PHP生成ECDSA算法签名

    <?php use Ramsey\Uuid\Uuid; class ItunesSignatureGenerator { private $appBundleID = 'www.u17.com' ...

  4. 从入门到自闭之Python整型,字符串以及for循环

    Day 01 整型: 对比: 在python 2 版本中有整型,长整型long 在python 3 版本中全部都是整型 用于计算和比较 整型和布尔值的转换 二进制转换成十进制: ​ print (in ...

  5. ELK电子书籍

    Elasticsearch in Action(英文版).pdfElasticsearch实战 in action(中文版).pdfElasticsearch技术解析与实战.pdfElasticsea ...

  6. Spark报错java.io.IOException: Could not locate executable null\bin\winutils.exe in the Hadoop binaries.

    Spark 读取 JSON 文件时运行报错 java.io.IOException: Could not locate executable null\bin\winutils.exe in the ...

  7. 《python解释器源码剖析》第0章--python的架构与编译python

    本系列是以陈儒先生的<python源码剖析>为学习素材,所记录的学习内容.不同的是陈儒先生的<python源码剖析>所剖析的是python2.5,本系列对应的是python3. ...

  8. 小黄车ofo法人被限制出境,它究竟还能撑多久?

    因为季节的原因,现在正是骑车的好时候,而且北京也开通了一条自行车的专用路.但就是在这么好的时候,我们发现,路边的小黄车却越来越少了,而且它的麻烦还不断! ofo法人被限制出境 6月12日消息,据上海市 ...

  9. 05-spring框架—— Spring 事务

    5.1 Spring 的事务管理 事务原本是数据库中的概念,在 Dao 层.但一般情况下,需要将事务提升到业务层,即 Service 层.这样做是为了能够使用事务的特性来管理具体的业务. 在 Spri ...

  10. Circle HDU - 6550 (数学)

    在半径为 1 的圆上有 n 个点,它们也是圆的 n 等分点,将每个相邻的 n 等分点相连,组成了一个正 n边形,现在你可以在圆上再增加一个点,使得新的 n + 1 边形的面积最大,请输出最大面积. I ...