[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, ...
随机推荐
- Unity VR-播放demo模型后无法移动视角
资源源于:小意思VR 唉..可怜一下自己,这个问题百度google也不知道怎么搜,没搜出来,在群里问出来的. 当时感觉自己Unity有问题..(就是因为自己啥也不会看不懂) 按右键.或者WASD视角都 ...
- 打印指针要用%p而不要用%x
注意: 打印指针要用%p而不要用%x 原因: https://boredzo.org/blog/archives/2007-01-23/please-do-not-use-percent-x-for- ...
- 生成ini文件
setProfileString是无法直接生成ini文件的,如果不存在这个ini文件需要先创建,然后再setProfileString.示例代码//保存连接参数到配置文件if not FileExis ...
- P3586 [POI2015]LOG
传送门 对于询问,首先如果正数数量不到 $c$ 个显然无解 然后如果大于等于 $s$ 的数大于等于 $c$ 个,那么显然有解 否则,考虑贪心地取数,首先初始大于等于 $s$ 的哪些数我们每次取都可以取 ...
- css中的position 的absolute和relative的区别(转)
我们先来看看CSS3 Api中对position属性的相关定义: static:无特殊定位,对象遵循正常文档流.top,right,bottom,left等属性不会被应用. relative:对象遵循 ...
- O023、理解Nova架构
参考https://www.cnblogs.com/CloudMan6/p/5410447.html Compute Service Nova 是OpenStack最核心的服务,负责维护和管理云环 ...
- css3实现div自动左右动
<!DOCTYPE html> <meta charset="UTF-8"/> <html> <head> <style> ...
- MySQL中导出用户权限设置的脚本
在对MySQL数据库进行迁移的时候,有时候也需要迁移源数据库内的用户与权限.对于这个迁移我们可以从mysql.user表来获取用户的相关权限来生成相应的SQL语句,然后在目标服务器上来执行生成的SQL ...
- kernel module insmod错误
kernel模块配置 Enable loadable module support 打开可加载模块支持,如果打开它则必须通过"make modules_install"把内核模块安 ...
- tp5之允许跨域请求
一.在app顶层创建文件common\behavior\CronRun.php 写入以下代码 <?php namespace app\common\behavior; use think\Exc ...