forked from liuyubobobo/Play-with-Data-Structures
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLinkedListR.java
208 lines (165 loc) · 5.3 KB
/
LinkedListR.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
import javafx.util.Pair;
/// 递归实现的LinkedList
/// 类名称中LinkedListR里的R,是Recursion的意思,表示递归实现:)
public class LinkedListR<E> {
private class Node{
public E e;
public Node next;
public Node(E e, Node next){
this.e = e;
this.next = next;
}
public Node(E e){
this(e, null);
}
public Node(){
this(null, null);
}
@Override
public String toString(){
return e.toString();
}
}
// 在链表的递归实现中,我们不使用虚拟头结点,也能无差异的处理位置0的问题:)
private Node head;
private int size;
public LinkedListR(){
head = null;
size = 0;
}
// 获取链表中的元素个数
public int getSize(){
return size;
}
// 返回链表是否为空
public boolean isEmpty(){
return size == 0;
}
// 在链表的index(0-based)位置添加新的元素e
public void add(int index, E e){
if(index < 0 || index > size)
throw new IllegalArgumentException("Add failed. Illegal index.");
head = add(head, index, e);
size ++;
}
// 在以node为头结点的链表的index位置插入元素e,递归算法
private Node add(Node node, int index, E e){
if(index == 0)
return new Node(e, node);
node.next = add(node.next, index - 1, e);
return node;
}
// 在链表头添加新的元素e
public void addFirst(E e){
add(0, e);
}
// 在链表末尾添加新的元素e
public void addLast(E e){
add(size, e);
}
// 获得链表的第index(0-based)个位置的元素
public E get(int index){
if(index < 0 || index >= size)
throw new IllegalArgumentException("Get failed. Illegal index.");
return get(head, index);
}
// 在以node为头结点的链表中,找到第index个元素,递归算法
private E get(Node node, int index){
if(index == 0)
return node.e;
return get(node.next, index - 1);
}
// 获得链表的第一个元素
public E getFirst(){
return get(0);
}
// 获得链表的最后一个元素
public E getLast(){
return get(size - 1);
}
// 修改链表的第index(0-based)个位置的元素为e
public void set(int index, E e){
if(index < 0 || index >= size)
throw new IllegalArgumentException("Update failed. Illegal index.");
set(head, index, e);
}
// 修改以node为头结点的链表中,第index(0-based)个位置的元素为e,递归算法
private void set(Node node, int index, E e){
if(index == 0){
node.e = e;
return;
}
set(node.next, index - 1, e);
}
// 查找链表中是否有元素e
public boolean contains(E e){
return contains(head, e);
}
// 在以node为头结点的链表中,查找是否存在元素e,递归算法
private boolean contains(Node node, E e){
if(node == null)
return false;
if(node.e.equals(e))
return true;
return contains(node.next, e);
}
// 从链表中删除index(0-based)位置的元素, 返回删除的元素
public E remove(int index){
if(index < 0 || index >= size)
throw new IllegalArgumentException("Remove failed. Index is illegal.");
Pair<Node, E> res = remove(head, index);
size --;
head = res.getKey();
return res.getValue();
}
// 从以node为头结点的链表中,删除第index位置的元素,递归算法
// 返回值包含两个元素,删除后的链表头结点和删除的值:)
private Pair<Node, E> remove(Node node, int index){
if(index == 0)
return new Pair<>(node.next, node.e);
Pair<Node, E> res = remove(node.next, index - 1);
node.next = res.getKey();
return new Pair<>(node, res.getValue());
}
// 从链表中删除第一个元素, 返回删除的元素
public E removeFirst(){
return remove(0);
}
// 从链表中删除最后一个元素, 返回删除的元素
public E removeLast(){
return remove(size - 1);
}
// 从链表中删除元素e
public void removeElement(E e){
head = removeElement(head, e);
}
// 从以node为头结点的链表中,删除元素e,递归算法
private Node removeElement(Node node, E e){
if(node == null)
return null;
if(node.e.equals(e)){
size --;
return node.next;
}
node.next = removeElement(node.next, e);
return node;
}
@Override
public String toString(){
StringBuilder res = new StringBuilder();
Node cur = head;
while(cur != null){
res.append(cur + "->");
cur = cur.next;
}
res.append("NULL");
return res.toString();
}
public static void main(String[] args) {
LinkedListR<Integer> list = new LinkedListR<>();
for(int i = 0 ; i < 10 ; i ++)
list.addFirst(i);
while(!list.isEmpty())
System.out.println("removed " + list.removeLast());
}
}