#include #include #include #include #include #include #include #include #include #define REP(i,k,n) for(int i=k;i P; struct edge { int from,to; int cost; edge(int t,int c) : to(t),cost(c) {} edge(int f,int t,int c) : from(f),to(t),cost(c) {} bool operator<(const edge &e) const { return cost < e.cost; } }; vector G[15]; int d[15]; void dijkstra(int s,int n) { priority_queue,greater

> que; fill(d,d+n,INF); d[s] = 0; que.push(P(0,s)); while(que.size()) { P p = que.top(); que.pop(); int v = p.second; if(d[v] < p.first) continue; rep(i,G[v].size()) { edge e = G[v][i]; if(d[e.to] > d[v] + e.cost) { d[e.to] = d[v] + e.cost; que.push(P(d[e.to],e.to)); } } } } int main() { int n,m; cin >> n >> m; rep(i,m) { int s,t,c; cin >> s >> t >> c; G[s].push_back(edge(t,c)); } int ans = 0; rep(i,m) { dijkstra(i,n); rep(j,n) { if(d[j] == INF) continue; ans = max(ans,d[j]); } } cout << ans << endl; return 0; }