http://poj.org/problem?id=2135
2.Idea
Min cost flow
3.Source
#define MAX_V 1005
#define INF 1000000000
struct edge{ int to, cap, cost, rev_index; };
int V;
vector<edge> G[MAX_V];
int dist[MAX_V];
int prevv[MAX_V], preve[MAX_V];
void add_edge(int from, int to, int cap, int cost){
G[from].push_back((edge){to, cap, cost, G[to].size()});
G[to].push_back((edge){from, 0, -cost, G[from].size() - 1});
}
int min_cost_flow(int s, int t, int f){
int res = 0;
while(f > 0){
fill(dist, dist + V, INF);
dist[s] = 0;
bool update = true;
while(update){
update = false;
for(int v = 0; v < V; v++){
if(dist[v] == INF) continue;
for(int i = 0; i < G[v].size(); i++){
edge &e = G[v][i];
if(e.cap > 0 && dist[e.to] > dist[v] + e.cost){
dist[e.to] = dist[v] + e.cost;
prevv[e.to] = v;
preve[e.to] = i;
update = true;
}
}
}
}
if(dist[t] == INF){
return -1;
}
int d = f;
for(int v = t; v != s; v = prevv[v]){
d = min(d, G[prevv[v]][preve[v]].cap);
}
f -= d;
res += d * dist[t];
for(int v = t; v != s; v = prevv[v]){
edge &e = G[prevv[v]][preve[v]];
e.cap -= d;
G[v][e.rev_index].cap += d;
}
}
return res;
}
int main(){
int N, M;
scanf("%d %d", &N, &M);
V = N;
while(M--){
int a, b, c;
scanf("%d %d %d", &a, &b, &c);
add_edge(a - 1, b - 1, 1, c);
add_edge(b - 1, a - 1, 1, c);
}
printf("%d\n", min_cost_flow(0, N - 1, 2));
}