-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathMoveToForwardSelfOrganizingList.cs
More file actions
48 lines (37 loc) · 1.09 KB
/
Copy pathMoveToForwardSelfOrganizingList.cs
File metadata and controls
48 lines (37 loc) · 1.09 KB
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
namespace AlgorithmsAndDataStructures.DataStructures.SelfOrganizingList;
public class MoveToForwardSelfOrganizingList<T>
{
private SelfOrganizingListNode<T> tail;
public SelfOrganizingListNode<T> Head { get; private set; }
public void Add(T value)
{
if (Head == null)
{
Head = new SelfOrganizingListNode<T> { Value = value };
tail = Head;
return;
}
tail.Next = new SelfOrganizingListNode<T> { Value = value };
tail = tail.Next;
}
public SelfOrganizingListNode<T> Get(T value)
{
if (Head == null) return null;
if (Head.Value.Equals(value)) return Head;
var current = Head.Next;
var previous = Head;
while (current != null)
{
if (current.Value.Equals(value))
{
previous.Next = current.Next;
current.Next = Head;
Head = current;
return current;
}
previous = current;
current = current.Next;
}
return null;
}
}