We can use remove_if in C++ to remove elements from a vector in linear time based on a predicate that operates on the elements.
bool condition(double d) {...} vector<double> data = ... std::remove_if (data.begin(), data.end(), condition); What if my condition depends not on the values, but on the indices? In other words, if I wanted to remove all the odd-indexed elements, or some arbitrary index set, etc?
bool condition(int index) {//returns whether this index should be removed} vector<double> data = ... std::remove_if (data.begin(), data.end(), ???);