CodeForces - 940 F - F. Machine Learning (이산 화 + 대모 대)

F. Machine Learning
time limit per test
4 seconds
memory limit per test
512 megabytes
input
standard input
output
standard output
You come home and fell some unpleasant smell. Where is it coming from?
You are given an array a. You have to answer the following queries:
  • You are given two integers l and r. Let ci be the number of occurrences of i in al: r, where al: r is the subarray of a from l-th element to r-th inclusive. Find the Mex of {c0, c1, ..., c109}
  • You are given two integers p to x. Change ap to x.

  • The Mex of a multiset of numbers is the smallest non-negative integer not in the set.
    Note that in this problem all elements of a are positive, which means that c0 = 0 and 0 is never the answer for the query of the second type.
    Input
    The first line of input contains two integers n and q (1 ≤ n, q ≤ 100 000) — the length of the array and the number of queries respectively.
    The second line of input contains n integers — a1, a2, ..., an (1 ≤ ai ≤ 109).
    Each of the next q lines describes a single query.
    The first type of query is described by three integers ti = 1, li, ri, where 1 ≤ li ≤ ri ≤ n — the bounds of the subarray.
    The second type of query is described by three integers ti = 2, pi, xi, where 1 ≤ pi ≤ n is the index of the element, which must be changed and 1 ≤ xi ≤ 109 is the new value.
    Output
    For each query of the first type output a single integer  — the Mex of {c0, c1, ..., c109}.
    Example
    input
    Copy
    10 4
    1 2 3 1 1 2 2 2 9 9
    1 1 1
    1 2 8
    2 7 1
    1 2 8
    

    output
    Copy
    2
    3
    2
    

    Note
    The subarray of the first query consists of the single element — 1.
    The subarray of the second query consists of four 2s, one 3 and two 1s.
    The subarray of the fourth query consists of three 1s, three 2s and one 3.
    제목:
    n (n < = 1e5) 개 수 를 드 리 겠 습 니 다. m 회 조회 (m < = 1e5), 매번 id x y 를 조회 합 니 다.
    만약 id = 1 이면 a [x] ~ a [y] 의 모든 수가 나타 난 횟수 중 1 부터 첫 번 째 가 나타 나 지 않 았 습 니 다.(예 를 들 어 1 번, 2 번, 4 번 이 나 온 숫자 가 있 으 면 정 답 은 3 이다)
    id = 2, a [x] 값 을 y 로 변경 합 니 다.
    생각:
    표준 대 수모 대.
    우선 a [i] 를 이산 화 합 니 다. 왜냐하면 우 리 는 매 수의 출현 횟수 를 요구 하기 때문에 값 자체 와 무관 합 니 다.
    그리고 표준 수리 대기 모 팀 의 판 자 를 붙 여 라.
    답 은 폭력 적 으로 찾 으 면 된다. 많 게 는 수백 번 이기 때문이다.
    이상 한 구덩이 가 있 습 니 다. 만약 에 조회 와 수 정 된 아래 표 가 0 부터 시작 하면 로 컬 테스트 가 통과 되 고 제출 하면 WA on test 1 입 니 다. 이 유 를 아 는 친구 가 댓 글 을 달 아 저 에 게 알려 주 기 를 바 랍 니 다.
    코드:
    #include 
    using namespace std;
    const int maxn=200010;
    int n,m,sz;
    int a[maxn],now[maxn];
    int num[maxn],cnt[maxn],ans[maxn];
    int be[maxn],siz;
    mapmp;
    struct node
    {
        int l,r,tim,id;
        bool operator0) cnt[num[i]]--;
        num[i]+=v;
        if(num[i]>0) cnt[num[i]]++;
    }
    void go(int i,int d)
    {
        if(l<=i&&i<=r)
        {
            add(a[i],-1);
            add(d,1);
        }
        a[i]=d;
    }
    
    int main()
    {
        int T,cas=1;
        while(scanf("%d%d",&n,&m)!=EOF)
        //scanf("%d%d",&n,&m);
        {
            sz=pow(n,0.666666);
            memset(num,0,sizeof(num));
            memset(cnt,0,sizeof(cnt));
            mp.clear();
            siz=0;
            for(int i=1;i<=n;i++)
            {
                scanf("%d",&a[i]);
                now[i]=a[i]=getid(a[i]);
                be[i]=(i-1)/sz+1;
            }
            m1=0;m2=0;
            for(int i=0;iq[i].tim) {go(c[t].pos,c[t].od);t--;}
    
                while(lq[i].l){add(a[l-1],1);l--;}
                while(rq[i].r){add(a[r],-1);r--;}
    
                int x=1;
                while(cnt[x]>0) x++;
                ans[q[i].id]=x;
            }
            for(int i=1;i<=m1;i++)
            {
                printf("%d
    ",ans[i]); } } return 0; }

    좋은 웹페이지 즐겨찾기