Submission #1041794

#TimeUsernameProblemLanguageResultExecution timeMemory
104179412345678Tenis (COI19_tenis)C++17
51 / 100
1078 ms2292 KiB
#include <bits/stdc++.h> using namespace std; const int nx=1e5+5; int n, q, p[4][nx], t, x, a, b, opr, mx[nx], res; void solve() { for (int i=1; i<=n; i++) mx[i]=0; for (int i=1; i<=n; i++) mx[min({p[1][i], p[2][i], p[3][i]})]++; res=n+1; for (int i=n; i>=1; i--) mx[i]+=mx[i+1]; for (int i=n; i>1; i--) if (mx[i]==(n-i+1)) res=i; } int main() { cin.tie(NULL)->sync_with_stdio(false); cin>>n>>q; for (int i=1; i<=n; i++) cin>>x, p[1][x]=i; for (int i=1; i<=n; i++) cin>>x, p[2][x]=i; for (int i=1; i<=n; i++) cin>>x, p[3][x]=i; solve(); while (q--) { cin>>opr; if (opr==1) cin>>a, cout<<(min({p[1][a], p[2][a], p[3][a]})<res?"DA\n":"NE\n"); else cin>>t>>a>>b, swap(p[t][a], p[t][b]), solve(); } }
#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...