-1

我为链表中的节点定义了以下类:

template <class T>
struct ListItem
{
    T value;
    List<T> wordList; // <--------
    ListItem<T> *next;
    ListItem<T> *prev;

    ListItem(T theVal)
    {
       this->value = theVal;
       this->next = NULL;
       this->prev = NULL;
    }
};

上面的类包含另一个类,即List,它有自己的功能,其中一个是insertAtEnd。我创建了一个 ListItem,我想通过调用 insertAtEnd 来更改它的 wordList 组件的值。这样做的语法是什么?

这是列表类:

template <class T>
class List
{
    ListItem<T> *head;

public:

    // Constructor
    List();         //done

    //test function
    void displaylist();

    // Copy Constructor
    List(const List<T>& otherList);       //done

    // Destructor
    ~List();

    // Insertion Functions
    void insertAtHead(T item);        //done
    void insertAtTail(T item);        //done
    void insertAfter(T toInsert, T afterWhat);    //done
    void insertSorted(T item);                    //done

    // Lookup Functions
    ListItem<T> *getHead();                       //done
    ListItem<T> *getTail();                       //done
    ListItem<T> *searchFor(T item);               //done

    // Deletion Functions
    void deleteElement(T item);                   //done
    void deleteHead();
    void deleteTail();                            //done

    // Utility Functions
    int length();                                 //done
 };

这是 insertAtTail 函数的实现。

template <class T>
void List<T>::insertAtTail(T item)
{
    ListItem<T>* a = new ListItem<T>(item);

    if(head==NULL)
    {
        head=a;
    }

    else
    {
        ListItem<T>* temp;
        temp=head;

        while(temp->next!=NULL)
        {
            temp=temp->next;
        }
        temp->next=a;
        a->prev=temp;
    }
}
4

2 回答 2

2

就像是

wordList.insertAtEnd( .... arguments ....);
于 2013-02-15T14:11:05.760 回答
1
  1. 我不知道你的确切用例,但我真的怀疑aListItem应该有List
  2. 简单地使用wordListdo this->wordList.insertAtEnd(........)(this在这里不是必须的)。
于 2013-02-15T14:12:39.763 回答