Submission #1069512

#TimeUsernameProblemLanguageResultExecution timeMemory
1069512MalixBeech Tree (IOI23_beechtree)C++17
0 / 100
1 ms604 KiB
#include "beechtree.h" #include<bits/stdc++.h> using namespace std; #define REP(a,b,c) for(int a=b;a<c;a++) #define PB push_back #define F first #define S second typedef long long ll; typedef vector<int> vi; typedef vector<vi> vii; typedef pair<int,int> pi; std::vector<int> beechtree(int n, int m, std::vector<int> p, std::vector<int> c) { if(n<=8){ vi ans(n,0); vii a(n); REP(i,0,n)a[i].PB(i); for(int i=n-1;i>=1;i--)for(auto u:a[i])a[p[i]].PB(u); REP(i,0,n)a[i].erase(a[i].begin()); vii b=a; REP(i,0,n){ int s=a[i].size(); if(s==0){ ans[i]=1; continue; } map<int,int> mp; bool flag=1; REP(j,0,s){ if(mp[c[b[i][j]]]!=p[b[i][j]]){ flag=0; break; } mp[c[b[i][j]]]++; } if(flag){ ans[i]=1; continue; } next_permutation(b[i].begin(),b[i].end()); while(b[i]!=a[i]){ mp.clear(); flag=1; REP(j,0,s){ if(mp[c[b[i][j]]]!=p[b[i][j]]){ flag=0; break; } mp[c[b[i][j]]]++; } if(flag)break; next_permutation(b[i].begin(),b[i].end()); } if(flag)ans[i]=1; } return ans; } return {}; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...