salist.h

来自「数据结构与算法分析」· C头文件 代码 · 共 27 行

H
27
字号
// Sorted array-based list
template <class Elem, class Compare>
class SAList: protected AList<Elem> {
public:
  SAList(int size=DefaultListSize) : AList<Elem>(size) {}
  ~SAList() {}                    // Destructor
  AList<Elem>::clear;  // Expose AList clear method
  // Redefine insert function to keep values sorted
  bool insert(const Elem& item) { // Insert at right
    Elem curr;
    for (setStart(); getValue(curr); next())
      if(!Compare::lt(curr, item)) break;
    return AList<Elem>::insert(item);
  }
  // All remaining methods are exposed from AList
  AList<Elem>::remove;
  AList<Elem>::setStart;
  AList<Elem>::setEnd;
  AList<Elem>::prev;
  AList<Elem>::next;
  AList<Elem>::leftLength;
  AList<Elem>::rightLength;
  AList<Elem>::setPos;
  AList<Elem>::getValue;
  AList<Elem>::print;
};

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?