Submission #795682

#TimeUsernameProblemLanguageResultExecution timeMemory
795682I_Love_EliskaM_Teams (IOI15_teams)C++14
34 / 100
4069 ms461572 KiB
#include "teams.h"
#include <bits/stdc++.h>
#pragma GCC optimize("O3")
#pragma target ("avx2")
using namespace std;
#define forn(i,n) for(int i=0;i<n;++i)
#define pb push_back
#define all(x) x.begin(),x.end()
using ll = long long;
#define pi pair<int,int>
#define f first
#define s second

const int sz=1<<20;
const int len = 1e7 + 5;
int sum[len], ls[len], rs[len], l[len], r[len], cnt = 0;
int build(int li, int ri)
{
  int vr = cnt++;
  l[vr] = li, r[vr] = ri, sum[vr] = 0;
  if (li != ri) ls[vr] = build(li, (li + ri) / 2), rs[vr] = build((li + ri) / 2 + 1, ri);
  return vr;
}
int upd(int i, int vr) // vrati novy koren
{
  if (i < l[vr] || i > r[vr]) return vr;
  int v2 = cnt++;
  sum[v2] = sum[vr] + 1;
  l[v2] = l[vr], r[v2] = r[vr];
  if (l[vr] != r[vr]) ls[v2] = upd(i, ls[vr]), rs[v2] = upd(i, rs[vr]);
  return v2;
}
int query(int li, int ri, int vr)
{
  if (ri < l[vr] || li > r[vr]) return 0;
  if (li <= l[vr] && r[vr] <= ri) return sum[vr];
  return query(li, ri, ls[vr]) + query(li, ri, rs[vr]);
}
int st[(int)5e5+5];

pi a[(int)5e5];
int n;

void init(int _n, int f[], int s[]) {
  n=_n;
  forn(i,n) a[i]={f[i],s[i]};
  vector<vector<int>> v(n+1);
  forn(i,n) v[a[i].s].pb(i);
  st[0]=build(0,n);
  forn(i,n) {
    st[i+1]=st[i];
    for(auto&x:v[i+1]) {
      st[i+1]=upd(a[x].f,st[i+1]);
    }
  } 
}

int can(int m, int k[]) {
  vector<int> v(m);
  forn(i,m) v[i]=k[i];
  sort(all(v));
  int s=0; forn(i,m) s+=k[i];
  if (s>n) return 0;

  vector<pi> z;
  forn(i,m) {
    if (!z.size()) {
      z.pb({v[i],1}); continue;
    }
    if (v[i]==z.back().f) z.back().s++;
    else z.pb({v[i],1});
  }
  int t=z.size();

  vector<int> dp(t+1,-1e9);
  dp[0]=0;

  forn(i,t) {
    forn(j,i+1) {
      int cnt;
      if (j==0) {
        cnt=query(0,z[i].f,st[n]) - query(0,z[i].f,st[z[i].f-1]);
      } else {
        cnt=query(z[j-1].f+1,z[i].f,st[n]) - query(z[j-1].f+1,z[i].f,st[z[i].f-1]);
      }
      dp[i+1]=max(dp[i+1],dp[j]+z[i].f*z[i].s-cnt);
    }
    if (dp[i+1]>0) return 0;
  }
  return 1;
}

Compilation message (stderr)

teams.cpp:4: warning: ignoring '#pragma target ' [-Wunknown-pragmas]
    4 | #pragma target ("avx2")
      | 
teams.cpp: In function 'int can(int, int*)':
teams.cpp:73:15: warning: conversion from 'std::vector<std::pair<int, int> >::size_type' {aka 'long unsigned int'} to 'int' may change value [-Wconversion]
   73 |   int t=z.size();
      |         ~~~~~~^~
teams.cpp:80:11: warning: declaration of 'cnt' shadows a global declaration [-Wshadow]
   80 |       int cnt;
      |           ^~~
teams.cpp:16:49: note: shadowed declaration is here
   16 | int sum[len], ls[len], rs[len], l[len], r[len], cnt = 0;
      |                                                 ^~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...