QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#294282 | #4901. Speike & Tom | Bronya | 50 | 71ms | 57036kb | C++14 | 3.8kb | 2023-12-30 11:18:05 | 2023-12-30 11:18:06 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
int n,m;
namespace Subtaskk1{
vector<int>a[2005],b[2005];
struct zt{
int x,y,op;
};
int f[2005][2005][2];
int d[2005][2005];
void Solve(){
for(int i=1;i<=n;i++)a[i].push_back(i),b[i].push_back(i);
for(int i=1;i<n;i++){
int u,v;
scanf("%d%d",&u,&v);
a[u].push_back(v);a[v].push_back(u);
b[u].push_back(v);b[v].push_back(u);
}
for(int i=1;i<=m;i++){
int u,v;
scanf("%d%d",&u,&v);
a[u].push_back(v);a[v].push_back(u);
}
for(int i=1;i<=n;i++){
sort(a[i].begin(),a[i].end());
a[i].resize(unique(a[i].begin(),a[i].end())-a[i].begin());
for(int j=1;j<=n;j++)
d[i][j]=a[i].size();
}
queue<zt>q;
for(int i=1;i<=n;i++)f[i][i][0]=f[i][i][1]=1,q.push({i,i,0}),q.push({i,i,1});
while(!q.empty()){
auto [x,y,op]=q.front();q.pop();
if(op==0){
for(auto z:b[y])
if(!f[x][z][1])f[x][z][1]=1,q.push({x,z,1});
}
else{
for(auto z:a[x]){
d[z][y]--;
if(d[z][y]==0&&!f[z][y][0])f[z][y][0]=1,q.push({z,y,0});
}
}
}
int ans=0;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
if(i!=j&&!f[i][j][0])ans++;
printf("%d\n",ans);
}
}
namespace Subtaskk2{
vector<int>son[100005];
int s,t;
int fa[100005];
vector<int>hav[100005];
bool pd[100005];
void dfs(int u){
for(auto v:son[u]){
if(v==fa[u])continue;
fa[v]=u;
dfs(v);
}
}
void dfs2(int u,int rt,int dep){
pd[u]=true;hav[rt].push_back(dep);
for(auto v:son[u]){
if(pd[v])continue;
dfs2(v,rt,dep+1);
}
}
struct BIT{
const int lim=2e5,dl=1e5;
int t[200005];
int lowbit(int u){
return u&(-u);
}
void cl(){
memset(t,0,sizeof(t));
}
void add(int u,int val){
u+=dl;
while(u<=lim){
t[u]+=val;
u+=lowbit(u);
}
}
int Find(int u){
int sum=0;
u+=dl;
while(u){
sum+=t[u];
u-=lowbit(u);
}
return sum;
}
}T1;
void Solve(){
for(int i=1;i<n;i++){
int u,v;
scanf("%d%d",&u,&v);
son[u].push_back(v);son[v].push_back(u);
}
scanf("%d%d",&s,&t);
dfs(s);
vector<int>sb;
while(t){
sb.push_back(t);pd[t]=true;
t=fa[t];
}
if(sb.size()<=3){
puts("0");
return;
}
for(auto x:sb)dfs2(x,x,0),sort(hav[x].begin(),hav[x].end());
long long ans=0;
for(int i=0;i<sb.size();i++){
int u=sb[i];
for(auto x:hav[u])T1.add(x-i,1);
for(auto x:hav[u])ans+=T1.Find(n)-T1.Find(x-i);
}
T1.cl();
reverse(sb.begin(),sb.end());
for(int i=0;i<sb.size();i++){
int u=sb[i];
for(auto x:hav[u])ans+=T1.Find(n)-T1.Find(x-i);
for(auto x:hav[u])T1.add(x-i,1);
}
printf("%lld\n",ans);
}
}
int main(){
// freopen("sayaka.in","r",stdin);
// freopen("sayaka.out","w",stdout);
scanf("%d%d",&n,&m);
if(n<=2000&&m<=2000)Subtaskk1::Solve();
else if(m==1)Subtaskk2::Solve();
return 0;
}
詳細信息
Subtask #1:
score: 10
Accepted
Test #1:
score: 10
Accepted
time: 0ms
memory: 8636kb
input:
20 3 1 2 1 3 3 4 4 5 1 6 6 7 1 8 5 9 8 10 5 11 7 12 11 13 12 14 11 15 4 16 7 17 2 18 1 19 3 20 8 20 12 4 10 1
output:
307
result:
ok 1 number(s): "307"
Test #2:
score: 0
Accepted
time: 0ms
memory: 8652kb
input:
20 4 1 2 2 3 1 4 3 5 4 6 3 7 4 8 3 9 2 10 8 11 8 12 7 13 8 14 14 15 4 16 1 17 4 18 6 19 19 20 9 13 14 2 14 13 15 6
output:
343
result:
ok 1 number(s): "343"
Test #3:
score: 0
Accepted
time: 0ms
memory: 8584kb
input:
19 4 1 2 1 3 1 4 4 5 4 6 3 7 7 8 6 9 4 10 2 11 6 12 7 13 1 14 13 15 6 16 12 17 3 18 3 19 8 12 4 6 18 5 11 9
output:
314
result:
ok 1 number(s): "314"
Test #4:
score: 0
Accepted
time: 0ms
memory: 8716kb
input:
20 3 1 2 2 3 3 4 4 5 1 6 2 7 1 8 3 9 9 10 5 11 8 12 10 13 12 14 8 15 9 16 11 17 5 18 17 19 19 20 9 19 10 15 18 15
output:
358
result:
ok 1 number(s): "358"
Test #5:
score: 0
Accepted
time: 0ms
memory: 8764kb
input:
20 6 1 2 1 3 3 4 4 5 1 6 6 7 5 8 4 9 7 10 6 11 10 12 6 13 10 14 1 15 15 16 8 17 17 18 15 19 18 20 17 2 16 3 10 1 8 7 13 5 19 7
output:
361
result:
ok 1 number(s): "361"
Test #6:
score: 0
Accepted
time: 3ms
memory: 8644kb
input:
20 8 1 2 2 3 1 4 1 5 1 6 4 7 2 8 4 9 2 10 1 11 11 12 2 13 10 14 1 15 6 16 16 17 11 18 10 19 3 20 2 6 6 7 1 18 18 13 1 20 3 12 8 4 7 1
output:
324
result:
ok 1 number(s): "324"
Subtask #2:
score: 15
Accepted
Dependency #1:
100%
Accepted
Test #7:
score: 15
Accepted
time: 0ms
memory: 11800kb
input:
300 26 1 2 1 3 2 4 4 5 3 6 6 7 5 8 2 9 1 10 10 11 6 12 8 13 6 14 10 15 6 16 4 17 9 18 10 19 5 20 18 21 6 22 10 23 18 24 1 25 19 26 17 27 8 28 10 29 25 30 16 31 27 32 13 33 4 34 5 35 12 36 9 37 15 38 32 39 29 40 11 41 5 42 28 43 1 44 25 45 27 46 3 47 34 48 27 49 9 50 39 51 20 52 48 53 10 54 35 55 23 ...
output:
86687
result:
ok 1 number(s): "86687"
Test #8:
score: 0
Accepted
time: 4ms
memory: 11740kb
input:
300 40 1 2 1 3 3 4 4 5 5 6 3 7 6 8 5 9 2 10 1 11 10 12 11 13 7 14 10 15 6 16 7 17 5 18 12 19 15 20 18 21 15 22 8 23 12 24 23 25 18 26 10 27 4 28 4 29 16 30 20 31 15 32 9 33 6 34 33 35 22 36 27 37 12 38 21 39 37 40 29 41 41 42 32 43 4 44 1 45 12 46 34 47 24 48 20 49 33 50 25 51 47 52 6 53 25 54 5 55 ...
output:
88364
result:
ok 1 number(s): "88364"
Test #9:
score: 0
Accepted
time: 2ms
memory: 11648kb
input:
299 100 1 2 1 3 1 4 3 5 3 6 4 7 1 8 6 9 5 10 8 11 1 12 2 13 11 14 3 15 8 16 14 17 11 18 2 19 3 20 10 21 3 22 17 23 23 24 16 25 7 26 5 27 12 28 8 29 7 30 29 31 23 32 1 33 1 34 29 35 7 36 5 37 6 38 19 39 22 40 21 41 5 42 29 43 19 44 38 45 23 46 21 47 29 48 27 49 28 50 47 51 25 52 28 53 9 54 45 55 52 5...
output:
88551
result:
ok 1 number(s): "88551"
Test #10:
score: 0
Accepted
time: 0ms
memory: 11920kb
input:
300 10 1 2 2 3 3 4 1 5 2 6 5 7 5 8 7 9 2 10 7 11 1 12 4 13 2 14 5 15 8 16 7 17 11 18 13 19 14 20 2 21 8 22 18 23 23 24 16 25 22 26 13 27 9 28 22 29 3 30 19 31 28 32 6 33 12 34 9 35 27 36 17 37 36 38 17 39 9 40 37 41 32 42 11 43 37 44 42 45 34 46 26 47 39 48 16 49 42 50 24 51 39 52 38 53 32 54 24 55 ...
output:
82854
result:
ok 1 number(s): "82854"
Test #11:
score: 0
Accepted
time: 2ms
memory: 11816kb
input:
300 67 1 2 2 3 3 4 1 5 5 6 4 7 6 8 4 9 5 10 4 11 10 12 2 13 8 14 9 15 3 16 4 17 5 18 12 19 1 20 17 21 6 22 4 23 18 24 18 25 14 26 20 27 7 28 26 29 2 30 14 31 20 32 6 33 30 34 29 35 19 36 33 37 12 38 7 39 35 40 9 41 3 42 42 43 33 44 27 45 25 46 7 47 5 48 24 49 47 50 23 51 19 52 41 53 19 54 1 55 27 56...
output:
88372
result:
ok 1 number(s): "88372"
Test #12:
score: 0
Accepted
time: 4ms
memory: 11416kb
input:
280 280 1 2 2 3 3 4 3 5 4 6 2 7 6 8 5 9 4 10 5 11 5 12 12 13 13 14 5 15 13 16 16 17 7 18 10 19 6 20 10 21 4 22 8 23 10 24 15 25 14 26 20 27 17 28 19 29 28 30 27 31 26 32 19 33 6 34 15 35 14 36 33 37 1 38 23 39 33 40 4 41 8 42 10 43 7 44 8 45 4 46 37 47 25 48 38 49 30 50 49 51 31 52 23 53 9 54 46 55 ...
output:
78036
result:
ok 1 number(s): "78036"
Subtask #3:
score: 15
Accepted
Dependency #2:
100%
Accepted
Test #13:
score: 15
Accepted
time: 0ms
memory: 11800kb
input:
300 26 1 2 1 3 2 4 4 5 3 6 6 7 5 8 2 9 1 10 10 11 6 12 8 13 6 14 10 15 6 16 4 17 9 18 10 19 5 20 18 21 6 22 10 23 18 24 1 25 19 26 17 27 8 28 10 29 25 30 16 31 27 32 13 33 4 34 5 35 12 36 9 37 15 38 32 39 29 40 11 41 5 42 28 43 1 44 25 45 27 46 3 47 34 48 27 49 9 50 39 51 20 52 48 53 10 54 35 55 23 ...
output:
86687
result:
ok 1 number(s): "86687"
Test #14:
score: 0
Accepted
time: 3ms
memory: 8504kb
input:
8 2 5 1 6 2 1 3 8 4 3 7 2 1 1 4 2 3 8 5
output:
34
result:
ok 1 number(s): "34"
Test #15:
score: 0
Accepted
time: 9ms
memory: 25956kb
input:
1000 80 1 2 1 3 3 4 1 5 1 6 4 7 3 8 7 9 5 10 9 11 6 12 6 13 3 14 5 15 7 16 4 17 13 18 12 19 13 20 13 21 8 22 10 23 3 24 18 25 7 26 2 27 15 28 14 29 1 30 8 31 22 32 28 33 3 34 34 35 4 36 25 37 3 38 25 39 29 40 29 41 22 42 10 43 27 44 12 45 27 46 27 47 39 48 42 49 13 50 30 51 46 52 34 53 16 54 49 55 1...
output:
988373
result:
ok 1 number(s): "988373"
Test #16:
score: 0
Accepted
time: 25ms
memory: 54528kb
input:
2000 40 1 2 2 3 1 4 4 5 5 6 1 7 7 8 3 9 7 10 3 11 7 12 12 13 3 14 2 15 15 16 16 17 4 18 3 19 18 20 17 21 1 22 17 23 7 24 16 25 6 26 14 27 12 28 13 29 15 30 13 31 30 32 30 33 33 34 28 35 22 36 9 37 7 38 10 39 12 40 5 41 26 42 10 43 27 44 1 45 18 46 34 47 26 48 47 49 24 50 34 51 37 52 28 53 15 54 32 5...
output:
3822427
result:
ok 1 number(s): "3822427"
Test #17:
score: 0
Accepted
time: 36ms
memory: 55752kb
input:
2000 10 1 2 1 3 1 4 3 5 1 6 6 7 4 8 2 9 1 10 6 11 3 12 9 13 13 14 14 15 12 16 14 17 15 18 15 19 16 20 13 21 4 22 9 23 2 24 4 25 1 26 13 27 7 28 20 29 4 30 9 31 14 32 14 33 8 34 5 35 18 36 31 37 11 38 37 39 17 40 20 41 40 42 29 43 24 44 21 45 15 46 38 47 1 48 47 49 35 50 32 51 26 52 9 53 14 54 25 55 ...
output:
3501231
result:
ok 1 number(s): "3501231"
Test #18:
score: 0
Accepted
time: 16ms
memory: 50668kb
input:
2000 200 1 2 2 3 1 4 3 5 2 6 4 7 2 8 1 9 4 10 9 11 9 12 8 13 10 14 9 15 6 16 5 17 5 18 4 19 3 20 11 21 14 22 13 23 20 24 15 25 24 26 19 27 16 28 23 29 28 30 30 31 16 32 5 33 20 34 1 35 9 36 5 37 30 38 15 39 6 40 40 41 31 42 25 43 28 44 42 45 2 46 7 47 34 48 2 49 35 50 42 51 28 52 38 53 35 54 51 55 2...
output:
3970625
result:
ok 1 number(s): "3970625"
Test #19:
score: 0
Accepted
time: 4ms
memory: 42116kb
input:
1998 1996 1 2 2 3 3 4 1 5 1 6 6 7 7 8 8 9 2 10 4 11 8 12 12 13 7 14 4 15 13 16 16 17 3 18 14 19 10 20 7 21 9 22 16 23 13 24 21 25 18 26 18 27 11 28 27 29 16 30 12 31 13 32 12 33 29 34 27 35 1 36 29 37 3 38 14 39 26 40 11 41 21 42 27 43 35 44 17 45 20 46 43 47 23 48 39 49 30 50 27 51 46 52 11 53 29 5...
output:
3989549
result:
ok 1 number(s): "3989549"
Test #20:
score: 0
Accepted
time: 71ms
memory: 57036kb
input:
1999 3 1 2 1 3 3 4 4 5 4 6 5 7 4 8 2 9 9 10 9 11 8 12 5 13 9 14 8 15 14 16 12 17 5 18 3 19 15 20 12 21 15 22 17 23 18 24 11 25 21 26 17 27 1 28 10 29 25 30 7 31 21 32 31 33 5 34 7 35 26 36 29 37 33 38 11 39 10 40 25 41 39 42 8 43 6 44 24 45 5 46 45 47 21 48 30 49 6 50 35 51 27 52 23 53 41 54 36 55 1...
output:
2959137
result:
ok 1 number(s): "2959137"
Subtask #4:
score: 0
Wrong Answer
Dependency #3:
100%
Accepted
Test #21:
score: 20
Accepted
time: 2ms
memory: 8536kb
input:
8 2 5 1 6 2 1 3 8 4 3 7 2 1 1 4 2 3 8 5
output:
34
result:
ok 1 number(s): "34"
Test #22:
score: -20
Wrong Answer
time: 0ms
memory: 8424kb
input:
40000 1000 1 2 1 3 3 4 3 5 3 6 1 7 3 8 6 9 9 10 2 11 3 12 7 13 12 14 8 15 13 16 5 17 11 18 15 19 1 20 12 21 11 22 15 23 10 24 12 25 12 26 3 27 3 28 28 29 24 30 29 31 23 32 1 33 21 34 14 35 23 36 3 37 34 38 12 39 24 40 25 41 40 42 27 43 9 44 31 45 35 46 31 47 18 48 21 49 44 50 48 51 2 52 44 53 18 54 ...
output:
result:
wrong answer Answer contains longer sequence [length = 1], but output contains 0 elements
Subtask #5:
score: 10
Accepted
Test #29:
score: 10
Accepted
time: 21ms
memory: 11944kb
input:
98765 1 2 1 3 1 4 2 5 2 6 5 7 4 8 6 9 7 10 7 11 6 12 1 13 11 14 13 15 7 16 6 17 14 18 4 19 13 20 14 21 11 22 21 23 1 24 13 25 7 26 16 27 8 28 21 29 20 30 10 31 12 32 10 33 7 34 31 35 29 36 29 37 30 38 34 39 38 40 14 41 40 42 26 43 33 44 1 45 44 46 25 47 14 48 2 49 30 50 26 51 46 52 34 53 32 54 31 55...
output:
0
result:
ok 1 number(s): "0"
Test #30:
score: 0
Accepted
time: 21ms
memory: 11980kb
input:
99824 1 2 1 3 1 4 1 5 1 6 2 7 2 8 1 9 3 10 9 11 4 12 6 13 6 14 2 15 3 16 9 17 13 18 15 19 4 20 13 21 12 22 15 23 5 24 16 25 17 26 9 27 26 28 18 29 8 30 23 31 5 32 31 33 28 34 5 35 11 36 20 37 6 38 36 39 35 40 4 41 11 42 10 43 12 44 28 45 15 46 38 47 9 48 36 49 16 50 45 51 49 52 44 53 6 54 12 55 5 56...
output:
0
result:
ok 1 number(s): "0"
Test #31:
score: 0
Accepted
time: 15ms
memory: 12036kb
input:
67765 1 2 1 3 2 4 1 5 2 6 2 7 3 8 4 9 3 10 5 11 6 12 4 13 7 14 13 15 11 16 11 17 3 18 8 19 2 20 13 21 19 22 7 23 14 24 7 25 6 26 21 27 1 28 1 29 2 30 16 31 9 32 31 33 26 34 1 35 21 36 10 37 32 38 16 39 38 40 10 41 20 42 23 43 8 44 10 45 14 46 42 47 12 48 17 49 45 50 28 51 42 52 49 53 44 54 9 55 8 56...
output:
2254349415
result:
ok 1 number(s): "2254349415"
Test #32:
score: 0
Accepted
time: 32ms
memory: 13104kb
input:
100000 1 2 1 3 1 4 3 5 4 6 2 7 1 8 2 9 5 10 3 11 9 12 10 13 3 14 12 15 13 16 11 17 8 18 14 19 8 20 16 21 7 22 18 23 19 24 21 25 5 26 10 27 22 28 21 29 8 30 17 31 10 32 30 33 7 34 22 35 13 36 30 37 8 38 20 39 23 40 11 41 17 42 35 43 2 44 13 45 17 46 37 47 4 48 37 49 11 50 26 51 45 52 45 53 18 54 44 5...
output:
4706707961
result:
ok 1 number(s): "4706707961"
Subtask #6:
score: 0
Skipped
Dependency #1:
100%
Accepted
Dependency #2:
100%
Accepted
Dependency #3:
100%
Accepted
Dependency #4:
0%