# |
Submission time |
Handle |
Problem |
Language |
Result |
Execution time |
Memory |
647337 |
2022-10-02T08:53:12 Z |
fatemetmhr |
Cities (BOI16_cities) |
C++17 |
|
5825 ms |
40088 KB |
// ~ Be Name Khoda ~ //
#include<bits/stdc++.h>
#pragma GCC optimize("Ofast,no-stack-protector,unroll-loops,fast-math")
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 |
2 ms |
2644 KB |
Output is correct |
3 |
Correct |
3 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 |
1431 ms |
21208 KB |
Output is correct |
2 |
Correct |
1439 ms |
20948 KB |
Output is correct |
3 |
Correct |
710 ms |
18316 KB |
Output is correct |
4 |
Correct |
73 ms |
7252 KB |
Output is correct |
5 |
Correct |
653 ms |
18196 KB |
Output is correct |
6 |
Correct |
73 ms |
7116 KB |
Output is correct |
7 |
Correct |
9 ms |
2900 KB |
Output is correct |
8 |
Correct |
4 ms |
2772 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
10 ms |
2900 KB |
Output is correct |
2 |
Correct |
10 ms |
2988 KB |
Output is correct |
3 |
Correct |
8 ms |
2900 KB |
Output is correct |
4 |
Correct |
7 ms |
2900 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
2921 ms |
27476 KB |
Output is correct |
2 |
Correct |
2876 ms |
27212 KB |
Output is correct |
3 |
Correct |
1733 ms |
24588 KB |
Output is correct |
4 |
Correct |
1285 ms |
17612 KB |
Output is correct |
5 |
Correct |
269 ms |
9080 KB |
Output is correct |
6 |
Correct |
78 ms |
8972 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
5825 ms |
40088 KB |
Output is correct |
2 |
Correct |
5699 ms |
40004 KB |
Output is correct |
3 |
Correct |
5001 ms |
39736 KB |
Output is correct |
4 |
Correct |
3217 ms |
37100 KB |
Output is correct |
5 |
Correct |
2547 ms |
23888 KB |
Output is correct |
6 |
Correct |
451 ms |
10400 KB |
Output is correct |
7 |
Correct |
90 ms |
9136 KB |
Output is correct |