본문으로 바로가기

[C#] 링크드 리스트 (Linked List)

category Program/C# 2019. 1. 23. 17:17
환경 : Visual Studio 2015

자료구조 : 링크드 리스트 (Linked List) 

링크드 리스트 (Linked List, 연결 리스트)는 데이타를 포함하는 노드들을 연결하여 컬렉션을 만든 자료 구조로서 각 노드는 데이타와 다음/이전 링크 포인터를 갖게 된다. 단일 연결 리스트(Singly Linked List)는 노드를 다음 링크로만 연결한 리스트이고 이중 연결 리스트는 각 노드를 다음 링크와 이전 링크 모두 연결한 리스트이다. 만약 링크를 순환해서 마지막 노드의 다음 링크가 처음 노드를 가리키게 했을 경우 이를 순환 연결 리스트 (Circular Linked List)라 부른다.
링크드 리스트는 특정 노드에서 노드를 삽입, 삭제하기 편리 하지만 ( O(1) ), 특정 노드를 검색하기 위해서는 O(n)의 시간이 소요된다.
 



LinkedList<T> 클래스 

.NET에는 링크드 리스트를 구현한 LinkedList<T> 클래스가 있다. 이 LinkedList 클래스는 이중 링크드 리스트로 구현되어 있으며, 리스트 노드는 LinkedListNode 클래스로 표현된다. 노드의 추가는 AddFirst, AddLast, AddBefore, AddAfter 등의 메서드들을 호출하여 처음 또는 끝, 혹은 특정 노드의 앞, 뒤에 새 노드를 추가할 수 있다. 

예제(아래 예는 Banana 노드 뒤에 Grape노드를 추가하는 예이다. )

LinkedList<string> list = new LinkedList<string>();
list.AddLast("Apple");
list.AddLast("Banana");
list.AddLast("Lemon");
            
LinkedListNode<string> node = list.Find("Banana");
LinkedListNode<string> newNode = new LinkedListNode<string>("Grape");

// 새 Grape 노드를 Banana 노드 뒤에 추가
list.AddAfter(node, newNode);

// 리스트 출력
list.ToList().ForEach(p => Console.WriteLine(p));

// Enumerator를 이용한 리스트 출력
foreach(var m in list)
{
    Console.WriteLine(m);
}



출력 화면



출처 : http://www.csharpstudy.com/DS/linkedlist.aspx


'Program > C#' 카테고리의 다른 글

[C#] Task 클래스  (0) 2019.01.24
[C#] 해시테이블 (Hash Table)  (0) 2019.01.23
[C#] 동적 배열 (Dynamic Array)  (0) 2019.01.23
[C#] 기초 실력 체크 테스트  (0) 2019.01.23
[C#] Nullable 타입의 도입  (0) 2019.01.23