我创建了一个模板化堆类,并设法通过使用自定义迭代器类按升序对列表进行排序,我只是想知道如何按相反顺序对其进行排序。
template <typename T>
inline void Heap<T>::sort_heap(DynamicArrayIter<T> first, DynamicArrayIter<T> second) {
int size = 0;
for (DynamicArrayIter<T> iter = first; iter != second; ++iter) {
size++;
}
T temp;
for (int i = 0; i < size; i++) {
for (int j = 0; j < size - 1; j++) {
if (contents.at(j) < contents.at(i)) {
temp = contents.at(i);
contents.at(i) = contents.at(j);
contents.at(j) = temp;
}
}
}
}
谢谢,Soz无法让代码插入工作......
答案 0 :(得分:-1)
修正了它,刚刚更改了
if (contents.at(j) < contents.at(i))
到
if (contents.at(j) > contents.at(i))