C언어 연결 리스트 (Linked List)

코딩C언어
읽는데 6분 소요
처음 쓰여진 날: 2026-02-03
마지막 수정일: 2026-02-03
조회수: 18

요약

C언어 연결 리스트의 기본 개념과 순회 방법을 알아봅니다. 정보처리기사 실기에 자주 출제되는 연결 리스트 순회 문제를 풀기 위한 핵심 개념을 정리합니다.

연결 리스트 핵심 정리

개념설명예시
노드(Node)데이터와 다음 노드 주소를 가진 구조체struct Node { int x; struct Node* next; };
NULL리스트의 끝을 표시next = NULL 또는 next = 0
순회(Traversal)리스트의 모든 노드를 방문while (curr) { curr = curr->next; }
연쇄 접근포인터를 따라 여러 노드를 거쳐 접근head->next->data

연결 리스트란?

연결 리스트(Linked List) 는 각 요소(노드)가 데이터와 다음 노드의 주소를 함께 저장하는 자료구조입니다.

배열과 달리 메모리에 연속적으로 저장되지 않고, 포인터로 연결됩니다.

c
코드 하이라이팅 중...
연결 리스트 개념
t3에서 시작해서 next 포인터를 따라 t2, t1 순서로 연결됩니다. t1의 next는 NULL(널)이므로 리스트의 끝입니다.

노드를 먼저 생성하고 나중에 연결하는 방식도 있습니다. 실기 문제에서 자주 출제되는 형태입니다.

c
코드 하이라이팅 중...


연결 리스트 순회

순회(Traversal) 는 리스트의 모든 노드를 처음부터 끝까지 방문하는 것입니다.

위에서 만든 연결 리스트를 순회하면서 각 노드의 데이터를 출력해봅시다.

c
코드 하이라이팅 중...
c
코드 하이라이팅 중...

실행 과정:

반복currcurr->xcurr->next출력
1회&t311&t211
2회&t27&t17
3회&t15NULL5
종료NULL---

최종 출력: 11 7 5

연결 리스트 순회
curr 포인터가 t3에서 시작해서 next를 따라 t2, t1 순서로 이동합니다.

while(curr)의 의미

while (curr)while (curr != NULL)과 같습니다. C언어에서 NULL은 0이고, 0은 거짓(false)으로 평가됩니다.

c
코드 하이라이팅 중...

연쇄 화살표 연산자 접근

연결 리스트에서 화살표 연산자(->)를 연속으로 사용하여 여러 노드를 거쳐 데이터에 접근할 수 있습니다.

c
코드 하이라이팅 중...

head->n2->n1의 의미

head->n2->n1왼쪽에서 오른쪽으로 순서대로 해석합니다.

단계표현의미결과
1headhead 포인터&a (a의 주소)
2head->n2head가 가리키는 노드(a)의 n2&b (b의 주소)
3head->n2->n1그 노드(b)의 n120
c
코드 하이라이팅 중...
연쇄 화살표 연산자 접근
head에서 시작해서 n2 포인터를 따라 b에 도착하고, b의 n1 값(20)을 출력합니다.

다양한 접근 예시

c
코드 하이라이팅 중...

연결 리스트 노드 값 스왑

연결 리스트를 순회하면서 인접한 두 노드의 값을 교환(스왑) 하는 패턴입니다. 노드 자체를 교환하는 것이 아니라 노드 안의 데이터 값만 교환합니다.

c
코드 하이라이팅 중...

스왑의 원리

스왑은 임시 변수를 사용해 두 값을 교환하는 기본 알고리즘입니다.

c
코드 하이라이팅 중...

연결 리스트에서는 n->vn->next->v를 스왑합니다.

실행 과정 예시

연결 리스트: n1(1) -> n3(3) -> n2(2) -> NULL

c
코드 하이라이팅 중...
반복n 위치n->vn->next->v스왑 후다음 n
1회n113n1.v=3, n3.v=1n2
2회n2-NULL조건 거짓, 종료-

최종 리스트: n1(3) -> n3(1) -> n2(2) -> NULL

while 조건의 의미

c
코드 하이라이팅 중...
  • n != NULL: 현재 노드가 존재하는지 확인
  • n->next != NULL: 다음 노드가 존재하는지 확인 (스왑 대상)

두 조건 모두 만족해야 스왑이 가능합니다. 하나라도 NULL이면 스왑할 쌍이 없으므로 종료합니다.


정보처리기사 실기 대비 문제