QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#255656 | #6645. 百合 | hongrock | TL | 0ms | 0kb | C++17 | 1.7kb | 2023-11-18 16:37:47 | 2023-11-18 16:37:48 |
answer
#include<bits/stdc++.h>
using namespace std;
using ll = long long;
const int N = 1 << 17;
const int M = 18;
const ll inf = (ll)1e18;
int K, m, s, n, a[M];
vector<pair<int,int>> V[N];
ll dist[N][M][M];
struct Node{
int id, x, y;
ll d;
Node(){}
Node(int id, int x, int y, ll d):id(id),x(x),y(y),d(d){}
bool operator < (const Node &A)const{
return d > A.d;
}
};
int main(){
int x, y, z;
scanf("%d %d %d", &K, &m, &s);
for(int i=1; i<=K; ++i) scanf("%d", a+i);
n = 1 << K;
while(m--){
scanf("%d %d %d", &x, &y, &z);
V[x].emplace_back(y, z);
V[y].emplace_back(x, z);
}
for(int i=0; i<n; ++i){
for(int j=0; j<=K; ++j){
for(int k=0; k<=K; ++k) dist[i][j][k] = inf;
}
}
dist[s][0][0] = 0;
priority_queue<Node> Q;
Q.emplace(s, 0, 0, 0);
while(!Q.empty()){
auto nd = Q.top(); Q.pop();
if(nd.d > dist[nd.id][nd.x][nd.y]) continue;
if(nd.d + a[nd.y] < dist[nd.id][0][0]){
dist[nd.id][0][0] = nd.d + a[nd.y];
Q.emplace(nd.id, 0, 0, dist[nd.id][0][0]);
}
if(nd.x < K){
if(nd.d < dist[nd.id][nd.x+1][nd.y]){
dist[nd.id][nd.x+1][nd.y] = nd.d;
Q.emplace(nd.id, nd.x+1, nd.y, nd.d);
}
int to = nd.id ^ (1 << nd.x);
if(nd.d < dist[to][nd.x+1][nd.y+1]){
dist[to][nd.x+1][nd.y+1] = nd.d;
Q.emplace(to, nd.x+1, nd.y+1, nd.d);
}
}
if(nd.x == 0 && nd.y == 0){
for(auto [to, z] : V[nd.id]){
if(nd.d + z < dist[to][0][0]){
dist[to][0][0] = nd.d + z;
Q.emplace(to, 0, 0, dist[to][0][0]);
}
}
}
}
for(int i=0; i<n; ++i){
printf("%lld%c", dist[i][0][0], " \n"[i == n - 1]);
}
return 0;
}
詳細信息
Test #1:
score: 0
Time Limit Exceeded
input:
17 176734 32035 174241040 312806717 869838047 1051792036 618192507 729602782 144984364 904057367 922632751 676477964 651564213 314995751 370303789 14711019 7843270 941966995 532030000 50422 32035 12218 70235 32035 1913 84994 70235 27964 94874 84994 3469 32802 50422 6989 18176 32802 17541 91233 50422...