Run Code
|
API
|
Code Wall
|
Misc
|
Feedback
|
Login
|
Theme
|
Privacy
|
Patreon
D. Traveling Graph
Language:
Ada
Assembly
Bash
C#
C++ (gcc)
C++ (clang)
C++ (vc++)
C (gcc)
C (clang)
C (vc)
Client Side
Clojure
Common Lisp
D
Elixir
Erlang
F#
Fortran
Go
Haskell
Java
Javascript
Kotlin
Lua
MySql
Node.js
Ocaml
Octave
Objective-C
Oracle
Pascal
Perl
Php
PostgreSQL
Prolog
Python
Python 3
R
Rust
Ruby
Scala
Scheme
Sql Server
Swift
Tcl
Visual Basic
Layout:
Vertical
Horizontal
#include <bits/stdc++.h> using namespace std; typedef long long int ll; const ll inf = (ll)1e18; ll g[16][16], dis[16][16], n; void Floydd(){ for(int j = 1; j <= n; j++) for(int k = 1; k <= n; k++) dis[j][k] = g[j][k]; for(int i = 1; i <= n; i++){ for(int j = 1; j <= n; j++) for(int k = 1; k <= n; k++) if(dis[j][k] > dis[j][i] + dis[i][k]) dis[j][k] = dis[j][i] + dis[i][k]; } } void print(){ for(int j = 1; j <= n; j++){ for(int k = 1; k <= n; k++) cout << dis[j][k] << " "; cout << endl; } } ll dp[16][40001]; ll foo(int from, int mask){ if(mask == ((1 << (n+1)) - 2)) return dis[from][1]; if(dp[from][mask] != inf) return dp[from][mask]; ll &ans = dp[from][mask]; ans = inf - 1; for(int j = 1; j <= n; j++){ if(mask & (1 << j) || g[from][j] == inf) continue; ans = min(ans, g[from][j] + foo(j, mask|(1 << j))); } return ans; } int main(){ for(int j = 0; j < 16; j++) for(int k = 0; k < 40001; k++) dp[j][k] = inf; int m; cin >> n >> m; for(int j = 0; j < 16; j++) for(int k = 0; k < 16; k++) g[j][k] = inf; while(m--){ ll u, v, w; cin >> u >> v >> w; g[u][v] = min(g[u][v], w); g[v][u] = min(g[v][u], w); } Floydd(); //print(); //cout << ((1 << (n+1)) - 2) << endl; cout << foo(1, 2) << endl; return 0; }
g++
4 6 1 2 10 2 3 1000 3 4 10 4 1 1000 4 2 5000 1 3 2
Show compiler warnings
[
+
] Compiler args
[
-
]
Show input
Compilation time: 1.53 sec, absolute running time: 0.19 sec, cpu time: 0.14 sec, memory peak: 6 Mb, absolute service time: 1,73 sec
edit mode
|
history
|
discussion
1032