代码拉取完成,页面将自动刷新
#include <bits/stdc++.h>
using namespace std;
#define int long long
const int maxn = 810;
const int INF = 1e18;
int S, T;
struct node
{
int y, z, w, nex;
} e[20010 * 4];
int head[maxn * 2], tot = 1, hd[maxn * 2];
int n, m;
void add(int x, int y, int z, int w)
{
e[++tot] = { y, z, w, head[x] };
head[x] = tot;
}
int ans, cost;
int d[maxn], vis[maxn];
bool spfa()
{
queue<int> q;
memset(d, 0x3f, sizeof(d));
memset(vis, 0, sizeof(vis));
d[S] = 0;
q.push(S);
while(!q.empty())
{
int x = q.front();
q.pop();
vis[x] = 0;
for(int i = head[x]; i; i = e[i].nex)
{
int v = e[i].y;
if(e[i].z && d[v] > d[x] + e[i].w)
{
d[v] = d[x] + e[i].w;
if(!vis[v])
vis[v] = 1, q.push(v);
}
}
}
return d[T] != 0x3f3f3f3f3f3f3f3f;
}
int dfs(int x, int in)
{
if(x == T || !in)
return in;
int out = 0;
vis[x] = 1;
for(int &i = hd[x]; i && in; i = e[i].nex)
{
int v = e[i].y;
if(!e[i].z || d[v] != d[x] + e[i].w || vis[v])
continue;
int res = dfs(v, min(in, e[i].z));
e[i].z -= res;
e[i ^ 1].z += res;
out += res;
in -= res;
}
return out;
}
void dinic()
{
while(spfa())
{
memcpy(hd, head, sizeof(head));
int k = dfs(S, INF);
ans += k;
cost += k * d[T];
}
}
signed main()
{
cin >> n >> m;
while(m--)
{
int x, y, z;
scanf("%lld%lld%lld", &x, &y, &z);
add(x + n, y, 1, z);
add(y, x + n, 0, -z);
}
for(int i = 1; i <= n; i++)
add(i, i + n, 1, 0), add(i + n, i, 0, 0);
S = 1 + n, T = n;
dinic();
printf("%lld %lld", ans, cost);
return 0;
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。