-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy path206.cpp
100 lines (97 loc) · 2.24 KB
/
206.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <iostream>
#include <fstream>
#include <algorithm>
#define rep(i,j,k) for (int i=j;i<=k;++i)
#define rrep(i,j,k) for (int i=j;i>=k;--i)
#define init(a,b) memset(a,b,sizeof(a));
using namespace std;
const int INF = 0x7FFFFFFF/2,maxn = 61,maxm=401,maxsize=401;
int N,M,W[maxsize][maxsize],edgeNum,size;
int g[maxn],lx[maxsize],ly[maxsize],link[maxsize],slack[maxsize],ori[maxm];
bool visx[maxsize],visy[maxsize];
struct egdeNode{int v,w,next;}edge[maxn*maxm];
void insert(int u,int v,int w)
{
edgeNum++;
edge[edgeNum].v = v,edge[edgeNum].w = w;
edge[edgeNum].next = g[u],g[u] = edgeNum;
}
bool dfs(int prev,int now,int goal,int w,int pos)
{
if (now == goal) return true;
for (int i = g[now];i;i=edge[i].next)
if (edge[i].v != prev)
if (dfs(now,edge[i].v,goal,w,pos))
{
int tmp = (i%2==1)?i/2+1:i/2;
W[tmp][pos] = edge[i].w-w;
return true;
}
return false;
}
void theIniter()
{
int u,v,w;
cin >> N >> M;size = max(N-1,M-N+1);
rep(i,1,N-1) {cin >> u >> v >> w;insert(u,v,w);insert(v,u,w);ori[i] = w;}
rep(i,N,M)
{
cin >> u >> v >> w;
ori[i] = w;
dfs(-1,u,v,w,i-N+1);
}
rep(i,1,size) rep(j,1,size) lx[i] = max(lx[i],W[i][j]);
}
bool KMing(int x)
{
visx[x] = true;
rep(y,1,size)
{
if (visy[y]) continue;
if (lx[x]+ly[y]==W[x][y])
{
visy[y] = true;
if (link[y]==0 || KMing(link[y]))
{
link[y] = x;
return true;
}
}
else
slack[y] = min(slack[y],lx[x]+ly[y]-W[x][y]);
}
return false;
}
void theKMer()
{
rep(i,1,size)
{
rep(j,1,size) slack[j] = INF;
for (;;)
{
init(visx,false);init(visy,false);
if (KMing(i)) break;int d = INF;
rep(j,1,size) if (!visy[j]) d = min(d,slack[j]);
rep(j,1,size) if (visx[j]) lx[j]-=d;
rep(j,1,size) if (visy[j]) ly[j]+=d;else slack[j]-=d;
}
}
}
void thePrinter()
{
rep(i,1,N-1) ori[i]-=lx[i];
rep(i,N,M) ori[i]+=ly[i-N+1];
rep(i,1,M) cout << ori[i] << endl;
}
int main()
{
ios::sync_with_stdio(false);
theIniter();
theKMer();
thePrinter();
return 0;
}