이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#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... |