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... |