[2019杭电多校第一场][hdu6582]Path(最短路&&最小割)
题目链接: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(最短路&&最小割)的更多相关文章
- 2019杭电多校第一场hdu6581 Vacation
Vacation 题目传送门 update(O(n)) 看了那个O(n)的方法,感觉自己想的那个O(nlogn)的好傻,awsl. 0车最终通过停车线的时候,状态一定是某个车堵住后面的所有车(这个车也 ...
- [2019杭电多校第一场][hdu6583]Typewriter(后缀自动机&&dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6583 大致题意是说可以花费p在字符串后添加一个任意字符,或者花费q在字符串后添加一个当前字符串的子串. ...
- [2019杭电多校第一场][hdu6579]Operation(线性基)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6579 题目大意是两个操作,1个是求[l,r]区间子序列的最大异或和,另一个是在最后面添加一个数. 如果 ...
- [2019杭电多校第一场][hdu6578]Blank(dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6578 计数问题想到dp不过分吧... dp[i][j][k][w]为第1-i位置中4个数最后一次出现的 ...
- 2019杭电多校第一场hdu6579 Operation(线性基)
Operation 题目传送门 解题思路 把右边的数尽量往高位放,构造线性基的时候同时记录其在原序列中的位置,在可以插入的时候如果那个位置上存在的数字的位置比新放入的要小,就把旧的往后挤.用这种发现构 ...
- 2018 Multi-University Training Contest 1 杭电多校第一场
抱着可能杭电的多校1比牛客的多校1更恐怖的想法 看到三道签到题 幸福的都快哭出来了好吗 1001 Maximum Multiple(hdoj 6298) 链接:http://acm.hdu.edu. ...
- 2019年杭电多校第一场 1009题String(HDU6586+模拟+单调栈)
题目链接 传送门 题意 给你一个字符串,要你构造一个长为\(k\)的子串使得每个字母出现的次数在\([L_i,R_i](0\leq i\leq26)\)间且字典序最小. 思路 做这种题目就是要保持思路 ...
- 2019年杭电多校第一场 1004题Vacation(HDU6581+数学)
题目链接 传送门 题意 有\(n+1\)辆车要过红绿灯,告诉你车的长度.与红绿灯的起点(题目假设红绿灯始终为绿).车的最大速度,问你第\(0\)辆车(距离最远)车头到达红绿灯起点的时间是多少(每辆车最 ...
- 2019年杭电多校第一场 1002题Operation(HDU6579+线性基)
题目链接 传送门 题意 初始时有\(n\)个数,现在有\(q\)次操作: 查询\([l,r]\)内选择一些数使得异或和最大: 在末尾加入一个数. 题目强制在线. 思路 对于\(i\)我们记录\([1, ...
随机推荐
- 右键添加cmd notePad++快捷键
1.将以下文字复制到txt文本,将txt修改为reg执行后,邮件菜单查. Windows Registry Editor Version 5.00 [HKEY_CLASSES_ROOT\Directo ...
- Scala学习一——基础
一.使用Scala解释器 如果以命令行的方式运行,输出的结果会把类型带上,且结果名默认为res0递增.且Scala解释器读到一个解释器求值打印然后读取下一个(这个过程为读取-求值-打印-循环[REPL ...
- Web前端开发中的小错误
Web前端开发中的小错误 错误1:表单的label标签跟表单字段没有关联 利用“for”属性允许用户单击label也可以选中表单中的内容.这可以扩大复选框和单选框的点击区域,非常实用. 错误2:log ...
- 【electronjs入门教程 】electronjs 介绍
官网地址:https://electronjs.org/ 官网文档地址:https://electronjs.org/docs/ electronjs使用 JavaScript, HTML 和 CSS ...
- vue配置路由时报错 Error in render: "RangeError: Maximum call stack size exceeded"
虽然标题写的是配置路由报错,最终也是通过修改路由解决的,但是导致报错的还有一个主要因素,是因为我增加了一个功能“页面刷新时,根据url高亮左侧导航”,如下图: 1.页面刷新,根据url高亮左侧导航代码 ...
- java apache-commons-collections中Map辅助类的使用
前言 apache-commons-collections中Map辅助类,很是有用.尽管我们通过原生Map经过业务逻辑处理也能达到相同的作用与效果,但毕竟作为一个开源的工具类辅助类,对它有个了解还是有 ...
- oracle数据库连接问题org.springframework.jdbc.support.MetaDataAccessException: JDBC DatabaseMetaData method not implemented by JDBC driver - upgrade your driver...
org.springframework.jdbc.support.MetaDataAccessException: JDBC DatabaseMetaData method not implement ...
- Qt Creator 4.10 Beta版发布
使用Qt Creator 4.10 Beta,现在支持固定文件,因此即使在关闭所有文件时它们仍然保持打开状态,围绕语言服务器协议支持继续集成,将Android目标添加到CMake/Qbs项目,支持Bo ...
- windows删除已注册服务
背景:近日,想要学习mysql主从复制,于是想在本地用多个mysql实例进行试验,试验的过程中总是挫折不断,生手不易,安装了很多实例,测试完成之后,想要删除这些实例. 虽然任务管理器可以停止任务,但是 ...
- CentOS 7 中英文桌面安装步骤详细图解
https://www.cnblogs.com/haoliyou/p/7694868.html