只寫了int類型光督,代碼感覺還可以再優(yōu)化淑翼,至于用模板則還要學習; 簡單起見,全寫在了一個cpp文件中
//double linked list (type int)
#include <iostream>
using namespace std;
class Node
{
public:
Node() {};
Node(int val) {
this->val =val;
prior = next = nullptr;
}
~Node() {};
void setVal(int val) { this->val = val; }
int getVal() {
return this->val;
}
Node* prior; //指向前節(jié)點指針
Node* next; //指向后節(jié)點指針
private:
int val=0;
};
class DLlist
{
public:
DLlist(int size) {
this->size = size;
head = new Node;
head->prior = nullptr;
head->next = nullptr;
tail = head;
for (int i = 0; i < this->size; i++)
{
int v;
cout << "Enter the value of No. " << i +1<< " Node: ";
cin >> v;
if (i==0)
{
head->setVal(v);
}
else
{
Node* temp=new Node;
temp->setVal(v);
temp->next = nullptr;
temp->prior = tail;
tail->next = temp;
tail = temp;
}
}
}
~DLlist() { Clear(); }
int getSize()
{
return this->size;
}
void insert(int num,int pos) //在兩節(jié)點間插入,插入位置的前后節(jié)點必須都存在
{
Node* temp = new Node;
Node* position;
temp->setVal(num);
position = GetPointer(pos);
(position->prior)->next = temp;
temp->next = position;
temp->prior = position->prior;
position->prior = temp;
size++;
}
void deleteList(int pos) //刪除節(jié)點阀溶,刪除位置的前后節(jié)點必須都存在
{
Node* position;
position = GetPointer(pos);
(position->prior)->next = position->next;
(position->next)->prior = position->prior;
delete position;
size--;
}
void addFirst(int element) //pushFront
{
if (head == nullptr)
{
head->setVal(element);
head->prior = nullptr;
head->next = nullptr;
tail = head;
size++;
}
else
{
/*我們要在頭結(jié)點前再插入一個結(jié)點腻脏,需要先創(chuàng)建一個新的結(jié)點,將頭結(jié)點的值保存在新節(jié)點银锻,然后讓新節(jié)點的下
個結(jié)點指向頭結(jié)點的下一個結(jié)點永品,再讓新節(jié)點的prior指向頭結(jié)點,這樣就將新節(jié)點與原來的鏈表融合了击纬,然后我
們將頭結(jié)點的數(shù)據(jù)換成element即可*/
Node* temp=new Node;
temp->setVal(head->getVal());
temp->next = head->next;
temp->prior = head;
if (size > 1)
{
(head->next)->prior = temp;
}
head->next = temp;
head->setVal(element);
size++;
}
}
void addLast(int element) //pushBack
{
if (head==nullptr)
{
head->setVal(element);
head->prior = nullptr;
head->next = nullptr;
tail = head;
size++;
}
else
{
Node* temp = new Node;
temp->setVal(tail->getVal());
temp->prior = tail->prior;
temp->next = tail;
if (size-1!=0)
{
(tail->prior)->next = temp;
}
tail->prior = temp;
tail->setVal(element);
size++;
}
}
int removeFirst()
{
int v = head->getVal();
head = head->next;
if (size > 1)
{
head->prior = nullptr;
}
size--;
return v;
}
int removeLast()
{
int v = tail->getVal();
tail =tail->prior;
if (size>1)
{
tail->next = nullptr;
}
size--;
return v;
}
int returnNth(int pos)
{
return GetPointer(pos)->getVal();
}
bool isEmpty()
{
if (size==0)
{
return true;
}
else
{
return false;
}
}
void printList()
{
for (int i = 0; i < size; i++)
{
cout << "No. " << i +1<< " = " << GetPointer(i)->getVal() << endl;
}
}
void Clear()
{
while (head != nullptr)
{
Node * temp = head->next;
delete head;
head = temp;
}
tail = nullptr;
size = 0;
}
private:
int size = 0;
Node* head; //指向頭節(jié)點的指針
Node* tail; //指向尾節(jié)點的指針
Node* GetPointer(int pos) //查找節(jié)點
{
Node* pNode = nullptr;
if (pos<0 || pos>size-1)
{
cout << "Out of range! " << endl;
}
else
{
pNode = head;
for (int i = 0; i < pos; i++)
{
pNode = pNode->next;
}
return pNode;
}
}
};
int main()
{
DLlist d(3);
cout << endl;
cout << "Size: " << d.getSize() << endl;
d.printList();
cout << endl;
cout << "Insert 10 at position 1" << endl;
d.insert(10, 1);
cout << "Size: " << d.getSize() << endl;
d.printList();
cout << endl;
cout << "Addfirst 100" << endl;
d.addFirst(100);
cout << "Now No.1's value= " << d.returnNth(0) << endl;
cout << endl;
cout << "Remove first" << endl;
d.removeFirst();
d.printList();
cout << endl;
cout << "Remove last" << endl;
d.removeLast();
d.printList();
cout << endl;
d.~DLlist();
cout << "Empty: " <<boolalpha<< d.isEmpty() << endl;
system("pause");
return 0;
}