#ifndef SELECTWITHPREDICTION_HPP
#define SELECTWITHPREDICTION_HPP

#include "DAG.hpp"
#include <vector>
#include <unordered_set>
#include <random>
#include <algorithm>

class SelectWithPrediction {
private:
    int comparison_cnt_dag;
    int comparison_cnt_sort;
    int BinarySearch(const std::vector<int>& arr, int val, bool flag);
public:
    int recursive_call = 0;
    SelectWithPrediction();
    int DeterministicSelect(std::vector<int>&A, int k, std::vector<bool>&active, const std::vector<std::vector<int>> &chains, const DirectedAcyclicGraph& dag, bool flag);
    int RandomizedSelect(std::vector<int> &A, int k, std::vector<bool>& active, std::vector<std::vector<int>>& chains, const DirectedAcyclicGraph& dag);
    int GetComparisonCount() const;
    int GetComparisonCountSort() const;
};

#endif
