0

我需要为数据结构课程制作一个自定义的双向链表。

但是列表的第一个元素是重复的,我看不到我的错误。

这是我的 push_back 功能:

template <class DT>
void List<DT>::push_back(const DT& elem)
{

    if(First->Back == nullptr && First->Forward == nullptr) {

        First->Current = elem;


        Last->Current = elem;
        Last->Back = First;

        First->Forward = Last;

        return;
    } else {


        ListObject<DT> *temp = new ListObject<DT>(*Last);

        Last = new ListObject<DT>(); Last->Back = temp; Last->Forward = nullptr; Last->Current = elem;
        temp->Back->Forward = temp;
        temp->Forward = Last;

    }

}

主要的

List<int> c;

    c.push_back(66);
    c.push_back(44);
    c.push_back(88);
    c.push_back(58);

    std::cout << "---------------------------" << std::endl;
    for(ListObject<int> *a = c.First; a; a = a->Forward) {

        std::cout << a->Current << std::endl;
    }

在这里编辑的是我的 ListObject 类

template <class LDT>
class ListObject {

public :

    ListObject* Back;
    LDT Current;
    ListObject* Forward;

    ListObject(const LDT& elem, ListObject&  _back, ListObject& _forward) {

        Back = &_back;
        Current = elem;
        Forward = &_forward;


    }

    ListObject() {
        Back = nullptr;
        Forward = nullptr;
    }

    ListObject(const ListObject& lista) {

        Back = lista.Back;
        Current = lista.Current;
        Forward = lista.Forward;
    }

    ~ListObject() {

        delete Back;
        delete Forward;
        Current;
    }

    ListObject<LDT> MakeList(const LDT& elem, ListObject&  _back, ListObject& _forward) {

        return  ListObject<LDT>::ListObject(elem, _back, _forward);
    }

    void assing(LDT elem) {

        Current = elem;

    }

    bool HasForward() {

        if(Forward != nullptr) {return true;} else{return false;}
    }



};
4

2 回答 2

1

修改你的 else 子句:

ListObject<DT> *temp = Last;

Last = new ListObject<DT>(); Last->Back = temp; Last->Forward = nullptr; Last->Current = elem;
temp->Forward = Last;

这将修复您的内存泄漏。

也将 if 子句替换为:

if(First == nullptr) { //list is empty

        First = new ListObject();
        First->Current = elem;

        First->Back = nullptr;
        First->Forward = nullptr;

        Last = First; //last IS also first, do not duplicate

        return;
}

这将修复重复的第一个元素。

于 2013-08-26T06:24:41.137 回答
1

正如 Neil 所说,在将第一项添加到列表时,您将值分配给 First 和 Last。恕我直言,Last-Current 应该什么都不是(空)

我相信第一项在列表中可能只出现两次。

于 2013-08-26T06:25:06.207 回答