2016-05-18 25 views
0

我已经创建了一个模板堆类,并设法通过使用自定义迭代器类以升序对列表进行排序,我只是想知道如何以相反的顺序对它进行排序。为模板堆类反向排序

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; 
      } 
     } 
    } 
} 

感谢,索兹无法获取代码插入到工作...

回答

-1

固定它,只是改变了

if (contents.at(j) < contents.at(i)) 

if (contents.at(j) > contents.at(i))