Submission #1057201

#TimeUsernameProblemLanguageResultExecution timeMemory
1057201Faisal_SaqibTeams (IOI15_teams)C++17
77 / 100
4043 ms175700 KiB
#pragma optimize("O2") #include <bits/stdc++.h> // #include "teams.h" using namespace std; const int N=5e5+100; struct { int lc,rc; int sum; }seg[N*30]; int nfi=0; int build(int l,int&r) { int cur=nfi; seg[cur].sum=0; nfi++; if(l==r) return cur; int mid=(l+r)/2; seg[cur].lc=build(l,mid); seg[cur].rc=build(mid+1,r); return cur; } // node =def= seg[node] is being changed // l,r are the range of seg[node](current segment) // x is the index to be update int update(int&node,int l,int&r,int&x) { int cur=nfi; nfi++; seg[cur]=seg[node]; if(l==r) { seg[cur].sum++; return cur; } int mid=(l+r)/2; if(x<=mid) seg[cur].lc=update(seg[cur].lc,l,mid,x); else seg[cur].rc=update(seg[cur].rc,mid+1,r,x); seg[cur].sum=seg[seg[cur].lc].sum+seg[seg[cur].rc].sum; return cur; } int get(int&node,int l,int&r,int&ql,int&qr) { if(qr<l or r<ql)return 0; if(ql<=l and r<=qr) return seg[node].sum; int mid=(l+r)/2; if(qr<=mid) return get(seg[node].lc,l,mid,ql,qr); else if(mid<ql) return get(seg[node].rc,mid+1,r,ql,qr); else return get(seg[node].lc,l,mid,ql,qr)+get(seg[node].rc,mid+1,r,ql,qr); } int n,a[N],b[N],till[N],cup; vector<int> add[N],rem[N]; void init(int Ng, int A[], int B[]) { n=Ng; for(int i=0;i<n;i++) { a[i]=A[i]; b[i]=B[i]; add[a[i]].push_back(b[i]); } till[0]=build(1,n); cup=till[0]; for(int i=1;i<=n;i++) { for(auto&j:add[i]) cup=update(cup,1,n,j); till[i]=cup; } } int Contains(int&l,int&r) { int ans=get(till[l],1,n,r,n); return ans; } int cnt[N]; // cnt of x int dp[N];// dp int can(int m, int k[]) { int sm=0; for(int i=0;i<m;i++) { sm+=k[i]; if(sm>n) { //Not Possible return 0; } } vector<int> kp; for(int i=0;i<m;i++) { cnt[k[i]]++; kp.push_back(k[i]); } sort(begin(kp),end(kp)); kp.resize(unique(begin(kp),end(kp))-begin(kp)); //Here we write the dp solution int mp=kp.size(); // number of different int mi=1e9; for(int i=0;i<mp;i++) { int x=kp[i]; int sz=cnt[x]*x; int cntx=Contains(x,x); dp[i]=cntx-sz; for(int j=i-1;j>=0;j--) dp[i]=min(dp[i],dp[j] + cntx - Contains(kp[j],x) - sz); mi=min(mi,dp[i]); } for(int i=0;i<mp;i++) cnt[kp[i]]=0; return (mi>=0); }

Compilation message (stderr)

teams.cpp:1: warning: ignoring '#pragma optimize ' [-Wunknown-pragmas]
    1 | #pragma optimize("O2")
      | 
teams.cpp: In function 'int can(int, int*)':
teams.cpp:110:19: warning: conversion from 'std::vector<int>::size_type' {aka 'long unsigned int'} to 'int' may change value [-Wconversion]
  110 |     int mp=kp.size(); // number of different
      |            ~~~~~~~^~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...