// In this file, we implement the random algorithm 
#include<bits/stdc++.h>
#include "oracle.h"
using namespace std;
// The elements keep elements in order they come.
vector<int> elements;
int k;

int ans()
{
  vector<int> S;
  for(int i = 0; i < min(k, (int)elements.size()); i ++)
    {
      int selected_element = elements[rand() % (elements.size())];
      if(find(S.begin(), S.end(), selected_element) == S.end())
	S.push_back(selected_element);
      else
	i --;
    }
  return f(S);
}

// Add element element_id
int add_element(int element_id)
{
  elements.push_back(element_id);
  return ans();
}

// Remove element_id
int remove_element(int element_id)
{
  for(int i = 0; i < elements.size(); i ++)
    if(elements[i] == element_id)
      {
	elements.erase(elements.begin() + i);
	break;
      }
  return ans();
}

void init(int K)
{
  srand(time(NULL));
  k = K;
}
