我需要为数据结构课程制作一个自定义的双向链表。
但是列表的第一个元素是重复的,我看不到我的错误。
这是我的 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;}
}
};