现在正在看数据结构,感觉清华大学出版的《数据结构与C++高级教程(第3版)》里翻译有很多逻辑上的错误,虽然如此,但书上还是有很多不错的地方的。今天看到链表,算是复习一下,先把代码帖出来,慢慢再总结:
listitem.h:
data:image/s3,"s3://crabby-images/8c6cf/8c6cf4ffdd445e63c151976879f2592b65c8c63d" alt=""
Code
1
#ifndef _LISTITEM_H_
2
#define _LISTITEM_H_
3data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
4
#include <iostream>
5
#include "listindexoutofrangeexception.h"
6
#include "listexception.h"
7data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
8
using namespace std;
9data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
10
typedef int DataType;
11data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
12data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt=""
class List
{
13data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
14
public:
15
List();
16
//Default constructor
17
List(const List &);
18
//Copy constructor
19data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
20
~List();
21
//Destructor
22data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
23
bool isEmpty() const;
24
//Determines whether a list is empty.
25
//Precondition:None.
26
//Postcondition:Return ture if the list is empty;
27
//Otherwise return false.
28data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
29
int getLength() const;
30
//Determines the length of the list
31
//Precondition:None
32
//Postcondition: Return the number of items that are currently in the list.
33data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
34
void insert(int position, DataType newItem);
35
//throw(ListIndexOutOfRangeException, ListException);
36
//Inserts an item into the list at position index.
37
//Precondition:the position indicates the item should be inserted in the list.
38
//Postcondition:if 1 <= position <= getLength()+1, the newItem will be inserted
39
//at the given position.
40
//Otherwise it will be thrown a exception.
41data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
42
void remove(int position);
43
//throw(ListIndexOutOfRangeException);
44
//Deletes an item from the list at a given position.
45
//Precondition:position indicates where the deletion should occur.
46
//Postcondition: if 1 <= position <= getLength(),
47
//the item at position index in the list is deleted, other throw a excepetion.
48data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
49
void retrieve(int position, DataType &dataItem) const;
50
//throw(ListIndexOutOfRangeException);
51
//Retrieves a list item by position.
52
//Precondition:position is the number of the item to be retrieved.
53
//Postcondition: if 1 <= position <= getLength(),
54
//dataItem is the value of the desired item.
55
//Otherwise throw a excepetion.
56data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
57
private:
58data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
59data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt=""
struct Node
{
60
DataType data;
61
Node *next;
62
};
63data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
64
int size;
65
Node *head;
66
private:
67
Node *find(int position) const;
68
//Return the node pointer given the position index.
69
};
70data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
71
#endif
72data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
listitem.cpp
data:image/s3,"s3://crabby-images/8c6cf/8c6cf4ffdd445e63c151976879f2592b65c8c63d" alt=""
Code
1
#include <iostream>
2
#include "ListItem.h"
3data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
4data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt=""
List::List(): size(0),head(NULL)
{
5data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
6
}
7data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
8data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt=""
List::List(const List &list)
{
9data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
10
}
11data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
12data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt=""
List::~List()
{
13
while(!isEmpty())
14
remove(1);
15data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
16
}
17data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
18data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt=""
bool List::isEmpty() const
{
19data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
20
return size ? false : true;
21
}
22data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
23data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt=""
int List::getLength() const
{
24
return size;
25
}
26data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
27data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt=""
List::Node* List::find( int position ) const
{
28
if(position < 1 || position > getLength() )
29
return NULL;
30data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt=""
else
{
31
Node *cur = head;
32
for(int skin = 1; skin < position; ++skin)
33
cur = cur->next;
34
return cur;
35
}
36
}
37data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
38data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
39data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt=""
void List::insert(int position , DataType data)
{
40
if( position < 1 || position > getLength() + 1)
41
return;
42
//throw ListIndexOutOfRangeException("ListOutOfRangeException : insert position out of range");
43data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt=""
else
{
44
Node *newItem = new Node;
45
if( newItem == NULL)
46
return;
47
//throw ListException( "ListException : insert cannot allocate memory");
48data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt=""
else
{
49
++size;
50
newItem->data = data;
51data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt=""
if( position == 1)
{
52
newItem->next = head;
53
head = newItem;
54data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt=""
} else
{
55
Node *prev = find( position - 1);
56
newItem->next = prev->next;
57
prev->next = newItem;
58
}
59
}
60
}
61
}
62data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
63data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt=""
void List::retrieve( int position, DataType &data ) const
{
64
if( position < 1 || position > getLength() )
65
return;
66
//throw ListIndexOutOfRangeException("ListOutOfRangeException : retrieve index out of range");
67data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt=""
else
{
68
Node *cur = find(position);
69
data = cur->data;
70
}
71
}
72data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
73data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt=""
void List::remove(int position)
{
74
Node *cur;
75data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
76
if(position < 1 || position > getLength())
77
return;
78
//throw ListIndexOutOfRangeException("ListOutOfRangeException : remove index out of range");
79data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt=""
else
{
80
--size;
81data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt=""
if(position == 1)
{
82
cur = head;
83
head = cur->next;
84
//head = head -> next; //Is different?
85data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt=""
} else
{
86
Node *prev = find(position - 1);
87
cur = prev->next;
88
prev->next = cur->next;
89
}
90
cur->next = NULL;
91
delete cur;
92
cur = NULL;
93
}
94
}
95data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
链表的实现,有的有头指针,有的没有。但有头指针的时候会减少很多麻烦,在理解上也比没有头指针要简单的多。
再就是有头指针的时候,在对链表进行删除/插入操作的时候只有一个特殊点:头结点。
删除结点时使用下面赋值语句,会减少很多灾难性的、难以理解的错误:
cur->next = NULL;
delete cur;
cur = NULL;
删除非头结点:
prev -> next = cur -> next;
cur->next = NULL;
delete cur;
cur = NULL;
特别地,删除头结点:
head = head -> next;
cur->next = NULL;
delete cur;
cur = NULL;
插入非头结点:
newItem -> next = cur;
prev->next = newItem;
特别地,插入头结点:
newItem -> next = head;
head = newItem;
复制链表时要使用深复制