This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#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 time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |