我试图实现一个使用排序选择排序随机生成的载体功能。 我想一个简单的方式只是为了看看,如果我能得到它的正常工作。 这里是我的尝试:
void selection_sort(std::vector<int>& v)
{
int pos, min, i;
//std::vector<int>::iterator pos, min, i;
for( pos = v[0]; pos < v[30]; ++pos)
{
min = pos;
for( i = v[pos + 1]; i < v[30]; ++i)
{
if( i < min)
{
min = i;
}
}
if( min != pos)
{
std::swap(v.at(min), v.at(pos));
}
}
}
出于某种原因,但是当我再次显示向量,所有的元素都在以相同的顺序,因为他们原本。 我如果我不使用我不知道std::swap
正确,或者如果我的选择排序是不正确写入。 我相信答案是十分容易的,但我无法看到它。 感谢您的帮助提前。