QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#20889 | #857. Social Distancing | uezexh | AC ✓ | 1197ms | 13484kb | C++17 | 2.7kb | 2022-02-20 18:53:20 | 2022-05-03 11:50:36 |
Judging History
answer
#include <cstdio>
#include <cassert>
#include <vector>
#include <algorithm>
#include <functional>
using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
template<typename T> void cmin(T &a,const T &b){if(b<a)a=b;}
template<typename T> void cmax(T &a,const T &b){if(a<b)a=b;}
struct Solver{
Solver(int n,const vector<vector<int>> &edge,const vector<int> &p):n(n),edge(edge),b(n){
for(int i:p){
assert(0<=i && i<n);
b[i]=1;
}
}
int n;
vector<vector<int>> edge;
vector<int> b,v;
vector<pii> step;
vector<int> dep;
void addstep(int u,int v){
step.emplace_back(u,v);
b[u]=0,b[v]=1;
}
void dfs(int x,int p){
for(auto y:edge[x]){
if(y==p)
continue;
dep[y]=dep[x]+1;
dfs(y,x);
}
}
int dfs_d(int x,int p){
int s=0;
for(auto y:edge[x]){
if(y==p || v[y])
continue;
if(dfs_d(y,x) && b[x])
addstep(x,y);
s|=b[y];
}
return !(b[x] || s);
}
int dfs_u(int x,int p){
vector<int> ch;
for(auto y:edge[x]){
if(y==p || v[y])
continue;
if(b[y])
ch.push_back(y);
}
if(!ch.size()){
for(auto y:edge[x]){
if(y==p || v[y])
continue;
if(dfs_u(y,x))
return addstep(y,x),1;
}
return 0;
}else if(int(ch.size())==1){
return addstep(ch[0],x),1;
}else{
int t=-1;
for(int i=0;i<int(ch.size());++i){
int y=ch[i];
if(t==-1 && i==int(ch.size())-1)
return addstep(y,x),1;
dfs_d(y,x);
if(b[y]){
if(t!=-1)
return 0;
t=y;
}
}
return addstep(t,x),1;
}
}
vector<pii> solve(){
vector<int> deg(n);
for(int i=0;i<n;++i)
deg[i]=edge[i].size();
dep.assign(n,0),dfs(0,-1);
vector<pii> p;
for(int i=0;i<n;++i)
p.emplace_back(dep[i],i);
sort(p.begin(),p.end()),reverse(p.begin(),p.end());
v.resize(n);
for(auto [_,p]:p){
if(!b[p] && !v[p])
dfs_u(p,-1);
if(b[p])
for(int q:edge[p])
v[q]=1;
}
return step;
}
};
void Solve(){
int n,k;
scanf("%d",&n);
vector<vector<int>> edge(n);
for(int i=1,u,v;i<n;++i){
scanf("%d%d",&u,&v),--u,--v;
edge[u].push_back(v);
edge[v].push_back(u);
}
scanf("%d",&k);
vector<int> sv(k),cv(k);
for(int &i:sv)
scanf("%d",&i),--i;
for(int &i:cv)
scanf("%d",&i),--i;
Solver s(n,edge,sv);
Solver c(n,edge,cv);
auto vs=s.solve(),vc=c.solve();
if(s.b!=c.b)
return (void)(puts("NO"));
puts("YES");
printf("%d\n",int(vs.size()+vc.size()));
for(auto [i,j]:vs)
printf("%d %d\n",i+1,j+1);
reverse(vc.begin(),vc.end());
for(auto [i,j]:vc)
printf("%d %d\n",j+1,i+1);
}
int main(){
int T;
scanf("%d",&T);
while(T--)
Solve();
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 1ms
memory: 3284kb
input:
2 5 1 2 1 3 2 4 2 5 2 1 4 1 5 7 1 2 2 3 2 4 4 6 6 5 6 7 3 1 4 5 3 4 7
output:
YES 4 1 3 4 2 2 5 3 1 NO
result:
ok OK!
Test #2:
score: 0
Accepted
time: 1035ms
memory: 3196kb
input:
100000 18 16 7 18 3 13 8 12 16 17 10 12 4 9 15 2 5 13 6 17 11 12 1 5 6 3 2 17 2 1 2 4 15 14 17 7 1 6 8 15 16 17 18 2 10 11 12 13 14 18 19 3 10 3 5 15 7 9 18 3 9 19 11 11 17 10 4 14 17 7 17 6 9 15 2 12 17 9 8 5 11 9 13 1 13 3 16 9 2 4 5 8 13 16 17 18 19 2 3 4 6 8 13 17 18 19 20 20 14 6 10 3 13 10 4 7...
output:
NO NO NO NO NO NO NO NO NO YES 3 19 15 15 19 19 2 NO NO NO NO NO YES 7 8 15 6 18 1 3 3 17 17 3 14 7 5 4 YES 18 10 17 4 13 13 15 14 18 1 5 2 6 6 4 4 6 6 2 18 14 14 3 15 13 17 10 10 12 13 15 7 11 5 1 8 16 NO NO NO YES 8 4 9 1 11 11 1 1 2 8 14 12 15 9 4 4 6 YES 8 17 18 10 12 6 16 2 13 14 1 16 6 6 3 12 ...
result:
ok OK!
Test #3:
score: 0
Accepted
time: 741ms
memory: 3540kb
input:
1703 165 137 77 32 123 34 74 18 16 79 88 130 10 74 151 112 48 78 91 135 132 145 19 51 19 103 37 13 57 36 157 84 87 48 158 72 161 149 50 89 49 37 8 71 47 85 32 126 35 46 111 119 135 30 53 130 158 123 70 97 109 25 21 16 55 158 118 46 24 77 130 101 23 50 88 13 96 88 22 162 128 125 86 165 106 163 63 75 ...
output:
YES 193 61 96 96 133 133 118 118 158 158 48 48 74 74 151 151 155 155 110 110 65 160 103 103 133 133 118 118 158 158 48 48 74 74 35 35 156 156 62 119 135 135 8 8 37 37 103 103 133 133 118 118 158 158 48 48 74 74 151 151 155 155 29 30 53 53 135 135 8 8 37 37 103 103 133 133 118 118 158 158 48 48 59 59...
result:
ok OK!
Test #4:
score: 0
Accepted
time: 1197ms
memory: 3580kb
input:
10 2000 1768 1996 1796 195 468 1622 1574 1483 489 1043 257 1318 1288 818 1654 1667 695 1592 974 17 274 1323 116 1169 1052 1404 1568 1163 960 1695 802 950 544 419 595 238 1901 585 888 1527 1861 402 1186 353 1479 1805 373 955 1513 1254 1084 1403 1425 1630 1371 1881 574 1254 1749 806 1784 615 1705 511 ...
output:
NO NO NO NO NO NO NO YES 1689 1915 1119 1119 485 485 813 813 1139 1139 259 259 1842 1842 569 569 1998 1998 602 602 147 147 516 516 1359 1359 1303 1975 471 471 130 130 1580 1580 485 485 813 813 1139 1139 259 259 1842 1842 569 569 1998 1998 1339 1339 881 881 1263 1263 1660 14 1441 1441 587 587 612 612...
result:
ok OK!
Test #5:
score: 0
Accepted
time: 1176ms
memory: 13484kb
input:
10 1989 1562 1958 831 864 1079 73 509 988 920 770 498 1214 877 1208 211 1899 905 98 834 197 1054 1147 748 1041 923 816 1138 1592 129 1250 1091 1455 639 1720 1975 208 625 1692 884 1431 1128 1367 688 2 741 444 1462 1734 68 1133 1309 1666 1769 734 844 1372 275 134 1941 399 1110 1010 715 220 1133 1111 3...
output:
YES 495012 1657 882 882 635 635 1366 1366 1184 1184 1496 1496 309 309 1005 1005 201 201 858 858 110 110 541 541 221 221 770 770 920 920 1922 1922 437 437 269 269 223 223 236 236 1201 1201 1566 1566 1913 1913 1818 1818 222 222 583 583 1919 1919 181 181 1536 1536 1564 1564 1794 1794 948 948 691 691 25...
result:
ok OK!
Test #6:
score: 0
Accepted
time: 533ms
memory: 8900kb
input:
11 1981 1974 1563 23 1887 1820 1714 1134 840 1134 275 571 76 1536 1739 875 821 1857 1114 1110 860 787 1671 1676 1478 1335 480 1885 432 119 438 363 1743 447 96 667 651 1571 816 590 1452 557 1339 185 1119 1643 459 1638 1614 807 266 730 737 404 686 465 1796 202 214 1210 227 1402 1238 744 494 1435 1804 ...
output:
YES 130186 811 1717 330 919 1906 537 869 1629 1185 488 803 1971 1171 823 352 1605 1764 1902 320 319 162 1419 1759 1960 90 1698 1616 1871 184 690 466 1351 64 17 1862 1039 653 193 1418 764 636 1530 960 458 489 1191 814 1084 1555 585 27 1318 966 666 502 1099 790 1549 1926 1733 356 1859 1188 36 873 47 1...
result:
ok OK!