有可能经常删除序列中的最后一个,仍然涉及循环排序,所以问题是它与<的速度意义相关。 Kb大小的容器使用向量(而不是其他可用的容器和算法)并按原样使用它:
std::vector<int> elements;
bool single_element = false
while (!single_element)
{
ApplySomeAlgorithm(elements, params); //weighted, but simple and comparable with looped deleting bellow
std::sort (elements.begin(), elements.end(), sort_function); // simple sort on int
single_element = (int (elements.size()) > 1) ? false : true;
while (!single_element)
{
if !(ApplySomeAlgorithm1(elements.back())) // actually only getter
break;
else
elements.pop_back();
single_element = (int (elements.size()) > 1) ? false : true;
}
}