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

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

요약

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
코드 하이라이팅 중...

struct Node* next는 같은 타입(struct Node)의 다른 노드를 가리키는 포인터입니다. 이처럼 자기 자신과 같은 타입의 포인터를 멤버로 가지는 것을 자기참조 구조체라고 합니다. 이 포인터를 통해 노드끼리 서로 연결됩니다.

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

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

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

&는 주소 연산자로, &t2는 t2의 메모리 주소를 의미합니다. t3.next = &t2는 t3의 next에 t2의 주소를 저장하여 두 노드를 연결합니다.

노드 생성 후 연결 과정
Step 1: 각 노드가 독립적으로 존재하는 초기 상태. Step 2: 포인터 연결 후 완성된 연결 리스트.


연결 리스트 순회 기초

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

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

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

아래 코드에서 curr->x-> (화살표 연산자)는 포인터가 가리키는 구조체의 멤버에 접근하는 연산자입니다. curr->x는 "curr이 가리키는 노드의 x 값"을 의미합니다.

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이 유효한 주소를 가리키면 참이므로 반복을 계속하고, curr이 NULL이 되면 거짓이므로 반복을 멈춥니다.

구조체 초기화에서 struct Node t1 = { 0, 5u };처럼 next에 0을 넣으면 NULL 포인터를 의미합니다. 이 노드가 리스트의 마지막 노드가 되어 순회가 여기서 끝납니다.


연쇄 화살표 연산자 접근 심화

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

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
코드 하이라이팅 중...

->가 3단 이상 연결되어도 같은 방식으로 왼쪽부터 한 단계씩 풀어가면 됩니다.

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

(&변수)->멤버변수.멤버와 같아지는 이유는, &변수가 해당 변수의 주소이고, -> 연산자가 그 주소에 있는 구조체의 멤버에 접근하기 때문입니다. 결국 같은 구조체의 같은 멤버를 가리키므로 결과가 동일합니다.



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

관련 글

(34개)
제목태그시험
C언어 구조체 배열
C언어
-
C언어 구조체 포인터
C언어
-
C언어 함수 프로토타입
C언어
-