10029 | 2024-03-24 15:33:12 | 111 | Széfnyitás | cpp17 | Hibás válasz 47/100 | 85ms | 7440 KiB |
#include <bits/stdc++.h>
using namespace std;
#define int long long
signed main(){
ios::sync_with_stdio(false);
cin.tie(nullptr);
int N;
#ifdef DEBUG
start:
N=2+rand()%99;
// N=4;
#else
cin>>N;
#endif
int a[N+1],g[N+1][2];
for(int i=1;i<=N;i++){
#ifdef DEBUG
a[i]=rand()&1,g[i][0]=1+rand()%N,g[i][1]=1+rand()%N;
#else
cin>>a[i]>>g[i][0]>>g[i][1];
#endif
}
int K;
#ifdef DEBUG
K=N;
#else
cin>>K;
#endif
for(int _=0;_<1000;_++){
vector<int>b(N);
for(int i=0;i<N;i++){
b[i]=rand()&1;
}
map<vector<int>,vector<int>>m;
int ok=1;
for(int z=1;z<=N;z++){
vector<int>v(N),c(N*2);
int x=z;
for(int i=0;i<N;i++){
v[i]=a[x];
x=g[x][b[i]];
}
for(int i=0;i<N*2;i++){
c[i]=a[x];
x=g[x][a[x]];
}
if(m.count(v)&&m[v]!=c&&count(c.begin(),c.end(),0)&&count(c.begin(),c.end(),1)){
// for(int i:v)cout<<i<<' ';cout<<endl;
// for(int i:c)cout<<i<<' ';cout<<endl;
// for(int i:m[v])cout<<i<<' ';cout<<endl;
ok=0;
break;
}
m[v]=c;
}
if(ok){
vector<array<int,2>>t(1);
vector<int>r(1);
for(int z=1;z<=N;z++){
vector<int>v(N);
int x=z;
int y=0;
for(int i=0;i<N;i++){
v[i]=a[x];
if(t[y][a[x]]==0){
t[y][a[x]]=t.size();
t.emplace_back();
r.push_back(-1);
}
r[y]=b[i];
y=t[y][a[x]];
x=g[x][b[i]];
}
if(r[y]!=-1){
continue;
}
int xx=x;
vector<int>c(N*2);
for(int i=0;i<N*2;i++){
c[i]=a[x];
x=g[x][a[x]];
}
if(!count(c.begin(),c.end(),0)){
r[y]=1;
t[y][1]=y;
continue;
}
if(!count(c.begin(),c.end(),1)){
r[y]=0;
t[y][0]=y;
continue;
}
x=xx;
vector<int>w(N+1);
for(int i=0;i<N*2;i++){
r[y]=a[x];
if(w[g[x][a[x]]]){
t[y][a[x]]=w[g[x][a[x]]];
break;
}
w[x]=y;
t[y][a[x]]=t.size();
t.emplace_back();
r.push_back(-1);
y=t[y][a[x]];
x=g[x][a[x]];
}
if(r[y]==-1){
return 1;
}
}
if(count(r.begin(),r.end(),-1)){
return 1;
}
if(t.size()>50000){
return 1;
}
for(int z=1;z<=N;z++){
int x=z,y=0;
int k=0;
for(int i=0;i<100000;i++){
k+=r[y]!=a[x];
int xx=g[x][r[y]];
int yy=t[y][a[x]];
x=xx;
y=yy;
}
if(k>K){
cout<<z<<' '<<k<<'\n';
return 1;
}
}
#ifdef DEBUG
cout<<"OK"<<endl;
goto start;
#else
cout<<t.size()<<' '<<1<<'\n';
for(int i=0;i<t.size();i++){
cout<<r[i]<<' '<<t[i][0]+1<<' '<<t[i][1]+1<<'\n';
}
#endif
return 0;
}
}
#ifdef DEBUG
cout<<N<<endl;
for(int i=1;i<=N;i++){
cout<<a[i]<<' '<<g[i][0]<<' '<<g[i][1]<<endl;
}
#endif
return 1;
}
Részfeladat | Összpont | Teszt | Verdikt | Idő | Memória | ||
---|---|---|---|---|---|---|---|
subtask1 | 0/0 | ||||||
1 | Elfogadva | 4ms | 1764 KiB | ||||
2 | Elfogadva | 4ms | 1924 KiB | ||||
subtask2 | 0/16 | ||||||
3 | Elfogadva | 4ms | 2140 KiB | ||||
4 | Elfogadva | 4ms | 2368 KiB | ||||
5 | Elfogadva | 4ms | 2572 KiB | ||||
6 | Elfogadva | 4ms | 2680 KiB | ||||
7 | Elfogadva | 4ms | 2884 KiB | ||||
8 | Elfogadva | 4ms | 2988 KiB | ||||
9 | Hibás válasz | 4ms | 3212 KiB | ||||
10 | Hibás válasz | 4ms | 3260 KiB | ||||
11 | Hibás válasz | 4ms | 3268 KiB | ||||
12 | Elfogadva | 4ms | 3388 KiB | ||||
13 | Elfogadva | 4ms | 3624 KiB | ||||
subtask3 | 24/24 | ||||||
14 | Elfogadva | 17ms | 3732 KiB | ||||
15 | Elfogadva | 17ms | 3764 KiB | ||||
16 | Elfogadva | 17ms | 4000 KiB | ||||
17 | Elfogadva | 17ms | 3972 KiB | ||||
18 | Elfogadva | 17ms | 4232 KiB | ||||
19 | Elfogadva | 17ms | 4332 KiB | ||||
20 | Elfogadva | 17ms | 4540 KiB | ||||
21 | Elfogadva | 17ms | 4380 KiB | ||||
subtask4 | 23/23 | ||||||
22 | Elfogadva | 17ms | 4348 KiB | ||||
23 | Elfogadva | 17ms | 4352 KiB | ||||
24 | Elfogadva | 17ms | 4712 KiB | ||||
25 | Elfogadva | 17ms | 4588 KiB | ||||
26 | Elfogadva | 17ms | 4568 KiB | ||||
27 | Elfogadva | 17ms | 4592 KiB | ||||
28 | Elfogadva | 17ms | 4592 KiB | ||||
29 | Elfogadva | 17ms | 4644 KiB | ||||
subtask5 | 0/37 | ||||||
30 | Elfogadva | 4ms | 2140 KiB | ||||
31 | Elfogadva | 4ms | 2368 KiB | ||||
32 | Elfogadva | 4ms | 2572 KiB | ||||
33 | Elfogadva | 4ms | 2680 KiB | ||||
34 | Elfogadva | 4ms | 2884 KiB | ||||
35 | Elfogadva | 4ms | 2988 KiB | ||||
36 | Hibás válasz | 4ms | 3212 KiB | ||||
37 | Hibás válasz | 4ms | 3260 KiB | ||||
38 | Hibás válasz | 4ms | 3268 KiB | ||||
39 | Elfogadva | 4ms | 3388 KiB | ||||
40 | Elfogadva | 4ms | 3624 KiB | ||||
41 | Elfogadva | 17ms | 3732 KiB | ||||
42 | Elfogadva | 17ms | 3764 KiB | ||||
43 | Elfogadva | 17ms | 4000 KiB | ||||
44 | Elfogadva | 17ms | 3972 KiB | ||||
45 | Elfogadva | 17ms | 4232 KiB | ||||
46 | Elfogadva | 17ms | 4332 KiB | ||||
47 | Elfogadva | 17ms | 4540 KiB | ||||
48 | Elfogadva | 17ms | 4380 KiB | ||||
49 | Elfogadva | 17ms | 4348 KiB | ||||
50 | Elfogadva | 17ms | 4352 KiB | ||||
51 | Elfogadva | 17ms | 4712 KiB | ||||
52 | Elfogadva | 17ms | 4588 KiB | ||||
53 | Elfogadva | 17ms | 4568 KiB | ||||
54 | Elfogadva | 17ms | 4592 KiB | ||||
55 | Elfogadva | 17ms | 4592 KiB | ||||
56 | Elfogadva | 17ms | 4644 KiB | ||||
57 | Elfogadva | 68ms | 4872 KiB | ||||
58 | Elfogadva | 82ms | 5884 KiB | ||||
59 | Elfogadva | 82ms | 5748 KiB | ||||
60 | Elfogadva | 82ms | 5920 KiB | ||||
61 | Elfogadva | 85ms | 6536 KiB | ||||
62 | Elfogadva | 85ms | 7168 KiB | ||||
63 | Elfogadva | 82ms | 6316 KiB | ||||
64 | Elfogadva | 85ms | 7128 KiB | ||||
65 | Elfogadva | 82ms | 6420 KiB | ||||
66 | Elfogadva | 83ms | 6836 KiB | ||||
67 | Elfogadva | 85ms | 7440 KiB | ||||
68 | Elfogadva | 83ms | 6796 KiB |