QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#780674 | #9802. Light Up the Grid | Zhanghaoyi | WA | 14ms | 3792kb | C++23 | 2.1kb | 2024-11-25 12:18:18 | 2024-11-29 22:51:43 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
#define int long long
#define endl '\n'
int a[9];
int dis[17];
int fix(int x, int op){
if(op < 4)
return x ^ (1 << op);
else if(op < 6){
if(op == 4)
return x ^ 3;
else
return x ^ 12;
}
else if(op < 8){
if(op == 6)
return x ^ 5;
else
return x ^ 10;
}
else return x ^ 15;
}
void per(){
cin >> a[0] >> a[4] >> a[6] >> a[8];
a[1] = a[2] = a[3] = a[0];
a[5] = a[4];
a[7] = a[6];
for(int i = 0 ; i < 17 ;i ++ )
dis[i] = 1e9;
dis[15] = 0;
priority_queue<pair<int,int>> q;
q.push({0,15});
while(!q.empty()){
pair<int,int> tmp = q.top();
q.pop();
if(tmp.first > dis[tmp.second]) continue;
for(int i = 0 ; i < 9 ; i ++ ){
int pos = fix(tmp.second,i);
if(dis[pos] > a[i] + dis[tmp.second]){
dis[pos] = a[i] + dis[tmp.second];
q.push({dis[pos],pos});
}
}
}
dis[15] = 2 * min({a[0],a[4],a[6],a[8]});
}
int ge[17];
void solve()
{
int n;
cin >> n;
for(int i = 0 ; i < n ; i ++ ){
int x = 0;
if(i != 0) getchar();
string s;
for(int j = 0 ; j < 2 ; j++ ){
cin >> s;
for(int k = 0 ; k < 2; k ++ )
if(s[k] == '1')
x += (1 << k + 2 * j);
}
ge[i] = x;
}
int ans = 0;
while(1){
int pos = 17 ,d = 1e9;
for(int i = 0 ;i < n ; i++ ){
if(ge[i] != -1 && dis[ge[i]] < d){
pos = i;
d = dis[ge[i]];
}
}
if(d == 1e9) break;
ans += d;
for(int i = 0 ; i <n ; i ++ )
if(ge[i] != -1 && i != pos)
ge[i] ^= (15 ^ ge[pos]);
ge[pos] = -1;
}
cout << ans << endl;
}
signed main()
{
ios::sync_with_stdio(0);
cin.tie(0);cout.tie(0);
int t=1;
cin>>t;
per();
while(t--){
solve();
}
}
详细
Test #1:
score: 100
Accepted
time: 1ms
memory: 3792kb
input:
2 1000 100 10 1 4 10 00 01 00 00 10 00 01 1 11 11
output:
1121 2
result:
ok 2 number(s): "1121 2"
Test #2:
score: 0
Accepted
time: 0ms
memory: 3660kb
input:
2 1 1 1 1 4 10 00 01 00 00 10 00 01 1 11 11
output:
5 2
result:
ok 2 number(s): "5 2"
Test #3:
score: 0
Accepted
time: 0ms
memory: 3628kb
input:
1 1000000 1000000 1000000 1000000 1 11 11
output:
2000000
result:
ok 1 number(s): "2000000"
Test #4:
score: -100
Wrong Answer
time: 14ms
memory: 3640kb
input:
10000 8 2 7 8 8 00 01 00 11 00 10 11 11 10 10 01 10 01 00 10 11 8 11 01 11 00 01 10 11 11 00 01 01 01 01 00 11 10 9 00 00 01 01 10 11 00 01 11 10 11 00 11 11 00 11 01 10 9 11 11 10 00 11 00 11 01 00 10 01 11 00 01 01 01 10 01 11 00 01 01 01 10 10 00 11 11 11 11 10 ...
output:
34 32 36 36 40 38 42 38 40 42 36 44 34 37 39 34 29 39 40 40 38 41 46 38 31 40 37 38 34 35 32 42 34 38 42 40 46 34 39 36 29 38 40 40 45 39 39 38 38 40 42 29 43 42 36 42 46 40 41 34 42 40 37 33 34 40 38 37 42 40 36 38 29 34 34 38 36 39 38 38 36 38 35 36 36 34 42 42 38 38 40 40 40 42 38 29 36 40 38 36 ...
result:
wrong answer 6th numbers differ - expected: '36', found: '38'