编写一个函数来在链表上进行头部插入。它的一半工作是将对象插入头部并重新附加列表,但我以某种方式丢失了列表中的原始头节点。
如果列表是 [green, red, blue] 并且我尝试插入黄色,它会起作用,但新列表将是 [yellow, red, blue]。
节点类是:
template<class T>
class Node
{
public:
Node(T theData, Node<T>* theLink) : data(theData), link(theLink){}
Node<T>* getLink( ) const { return link; }
const T& getData( ) const { return data; }
void setData(const T& theData) { data = theData; }
void setLink(Node<T>* pointer) { link = pointer; }
private:
T data;
Node<T> *link;
};
列表存储在队列中,因此头部插入是该类的方法。队列前后都有私有变量,它们指向列表的相应位置。
template<class T>
void Queue<T>::headInsert(T& theData)
{
Node<T> *temp;
temp = front->getLink();
front->setLink(new Node<T>(theData, temp->getLink() ));
front = front->getLink();
}