# |
Submission time |
Handle |
Problem |
Language |
Result |
Execution time |
Memory |
647333 |
2022-10-02T08:46:28 Z |
fatemetmhr |
Cities (BOI16_cities) |
C++17 |
|
6000 ms |
44248 KB |
// ~ Be Name Khoda ~ //
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
#define pb push_back
#define mp make_pair
#define all(x) x.begin(), x.end()
#define fi first
#define se second
const int maxn = 1e6 + 10;
const int maxn5 = 1e5 + 10;
const int maxnt = 1.2e6 + 10;
const int maxn3 = 1e3 + 10;
const int mod = 1e9 + 7;
const ll inf = 1e18;
vector <pair<int, int>> adj[maxn5];
ll dp[(1 << 5) + 1][maxn5];
int imp[maxn5], cmpmask, n;
set <pair<ll, int>> av;
inline void dij(int mask){
av.clear();
for(int i = 0; i < n; i++)
av.insert({dp[mask][i], i});
while(av.size()){
int v = av.begin() -> se;
av.erase(av.begin());
for(auto [u, w] : adj[v]) if(dp[mask][u] > dp[mask][v] + w){
av.erase({dp[mask][u], u});
dp[mask][u] = dp[mask][v] + w;
av.insert({dp[mask][u], u});
}
}
return;
}
int main()
{
ios_base::sync_with_stdio(false);cin.tie(0);cout.tie(0);
int k, m; cin >> n >> k >> m;
for(int i = 0; i < k; i++){
cin >> imp[i];
imp[i]--;
}
for(int i = 0; i < m; i++){
int a, b, c; cin >> a >> b >> c;
a--; b--;
if(a == b)
continue;
adj[a].pb({b, c});
adj[b].pb({a, c});
}
for(int mask = 0; mask < (1 << k); mask++) for(int i = 0; i < n; i++)
dp[mask][i] = inf;
for(int i = 0; i < n; i++)
dp[0][i] = 0;
for(int i = 0; i < k; i++){
dp[1 << i][imp[i]] = 0;
for(auto [u, w] : adj[imp[i]])
dp[1 << i][u] = min(dp[1 << i][u], ll(w));
}
for(int mask = 0; mask < (1 << k); mask++){
dij(mask);
for(int v = 0; v < n; v++){
int nmask = (1 << k) - 1 - mask;
for(int sub = nmask; sub; sub = (sub - 1) & nmask){
dp[mask^sub][v] = min(dp[mask^sub][v], dp[mask][v] + dp[sub][v]);
}
}
}
ll ans = inf;
for(int i = 0; i < n; i++)
ans = min(ans, dp[(1 << k) - 1][i]);
cout << ans << endl;
}
/*
8 3 9
2 8 7
2 4 3
2 6 9
3 7 2
4 6 5
5 8 1
6 8 2
1 2 5
1 3 3
4 5 2
*/
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
2 ms |
2644 KB |
Output is correct |
2 |
Correct |
1 ms |
2644 KB |
Output is correct |
3 |
Correct |
1 ms |
2644 KB |
Output is correct |
4 |
Correct |
2 ms |
2644 KB |
Output is correct |
5 |
Correct |
2 ms |
2772 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
1447 ms |
21212 KB |
Output is correct |
2 |
Correct |
1299 ms |
25156 KB |
Output is correct |
3 |
Correct |
654 ms |
20496 KB |
Output is correct |
4 |
Correct |
87 ms |
10592 KB |
Output is correct |
5 |
Correct |
665 ms |
22316 KB |
Output is correct |
6 |
Correct |
71 ms |
10572 KB |
Output is correct |
7 |
Correct |
7 ms |
2816 KB |
Output is correct |
8 |
Correct |
4 ms |
2820 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
12 ms |
2900 KB |
Output is correct |
2 |
Correct |
11 ms |
2988 KB |
Output is correct |
3 |
Correct |
7 ms |
2900 KB |
Output is correct |
4 |
Correct |
6 ms |
2900 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
2816 ms |
27480 KB |
Output is correct |
2 |
Correct |
2949 ms |
31444 KB |
Output is correct |
3 |
Correct |
1611 ms |
26708 KB |
Output is correct |
4 |
Correct |
1209 ms |
21756 KB |
Output is correct |
5 |
Correct |
249 ms |
12932 KB |
Output is correct |
6 |
Correct |
75 ms |
12424 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
5715 ms |
40012 KB |
Output is correct |
2 |
Correct |
5647 ms |
44248 KB |
Output is correct |
3 |
Correct |
6000 ms |
44104 KB |
Output is correct |
4 |
Correct |
3073 ms |
39228 KB |
Output is correct |
5 |
Correct |
2349 ms |
28084 KB |
Output is correct |
6 |
Correct |
434 ms |
14248 KB |
Output is correct |
7 |
Correct |
99 ms |
12572 KB |
Output is correct |