이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
#define for_(i, s, e) for (int i = s; i < (int) e; i++)
#define for__(i, s, e) for (ll i = s; i < e; i++)
typedef long long ll;
typedef vector<int> vi;
typedef pair<int, int> ii;
#define endl '\n'
class Compare {
public:
bool operator() (pair<ll, ii> a, pair<ll, ii> b) {
return a.first > b.first;
}
};
const int MXK = 5, MXN = 2e5;
const ll INF = 1e15;
int n, k, m;
vi terminals;
ll dist[MXK+1][MXN+1];
int tid[MXN+1];
vector<pair<int, ll>> adj[MXN+1];
void calcDist() {
for_(i, 0, k) {
for_(j, 0, n) dist[i][j] = INF;
dist[i][terminals[i]] = 0;
priority_queue<pair<ll, int>, vector<pair<ll, int>>, greater<pair<ll, int>>> pq;
pq.push({0, terminals[i]});
while (pq.size()) {
int p = pq.top().second;
ll d = pq.top().first; pq.pop();
if (d > dist[i][p]) continue;
for (auto j: adj[p]) if (dist[i][j.first] > d+j.second) {
dist[i][j.first] = d+j.second;
pq.push({dist[i][j.first], j.first});
}
}
}
}
int main() {
#ifdef shiven
freopen("test.in", "r", stdin);
#endif
ios_base::sync_with_stdio(false);
cin.tie(0);
cin >> n >> k >> m;
memset(tid, -1, sizeof(tid));
terminals.resize(k);
for_(i, 0, k) {
cin >> terminals[i];
terminals[i] -= 1;
tid[terminals[i]] = i;
}
for_(i, 0, m) {
int a, b; ll d; cin >> a >> b >> d;
a -= 1; b -= 1;
adj[a].push_back({b, d}); adj[b].push_back({a, d});
}
calcDist();
ll ans = INF;
int till = (1 << k);
ll cost[n+1][till+1];
priority_queue<pair<ll, ii>, vector<pair<ll, ii>>, Compare> pq;
for_(i, 0, n) for_(x, 0, till) cost[i][x] = INF;
for_(i, 0, k) {
int temp = 1 << i;
cost[terminals[i]][temp] = 0;
pq.push({0, {terminals[i], temp}});
}
while (pq.size()) {
int p = pq.top().second.first, bm = pq.top().second.second;
ll d = pq.top().first; pq.pop();
if (d > cost[p][bm]) continue;
if (bm == till-1) ans = min(ans, d);
for_(x, 0, k) {
int temp = bm | (1 << x);
if (cost[p][temp] > d+dist[x][p]) {
cost[p][temp] = d+dist[x][p];
pq.push({cost[p][temp], {p, temp}});
}
}
for (auto j: adj[p]) {
int nbm = bm;
if (tid[j.first] != -1) nbm |= 1 << tid[j.first];
if (cost[j.first][nbm] > d+j.second) {
cost[j.first][nbm] = d+j.second;
pq.push({cost[j.first][nbm], {j.first, nbm}});
}
}
}
cout << ans << endl;
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |