비선형 자료구조 ( Non - Linear )

2025. 9. 28. 15:29·⭐C Sharp/15-6. 트리와 그래프

비선형 자료구조 ( Non - Linear Data Structure )

지금까지 데이터가 일렬로 보관되는 선형 자료구조에 대해 배웠다.

데이터의 여러 관계도를 나타낼 수 있는 비선형 자료구조에 대해 다뤄보겠다.

비선형 자료구조를 사용하는 이유 중 하나는 데이터 간의 관계도 혹은 계층을 표현하기 위함이 크다.

비선형 자료구조는 그 종류가 정말 많은데, 사용하는 목적 경우에 따라 아주 다양한 자료구조로 활용할 수 있다.

비선형 자료구조에는 대표적으로 두 가지의 기본 형태인 그래프와 트리가 있다.

그래프 ( Graph ) 는 다소 불규칙적인 연결 관계를 보여준다.

트리 ( Tree ) 는 깔끔하게 정렬되어 있는 모습을 보여준다.

 

비선형 자료구조란?

데이터가 계층적 ( Hierarchical ) 또는 망 ( Network ) 형태로 연결되어 있는 구조

원소들이 단일 직선 ( 선형 ) 으로 나열되지 않고, 하나의 원소가 여러 개와 연결될 수 있다.

탐색 , 삽입 , 삭제가 더 복잡할 수 있지만 복잡한 관계를 표현하기 유리하다.

 

 

▼그래프 ( Graph )

그래프 ( Graph ) 는 정점 ( Vertex , Node ) 과 간선 ( Edge ) 으로 이루어진 자료구조이다.

객체 간의 관계를 표현하는데 사용한다.

정점은 개체를 나타내고 , 간선은 두 정점 간의 연결 관계를 의미한다.

 

▼정점 ( Vertex , Node )

정의 : 그래프에서 표현하는 대상 ( 객체 , 데이터 , 위치 등 )

예시 : 

  • 소셜 네트워크 - 사람 한명
  • 지도 - 도시 , 역
  • 웹 - 웹 페이지

표현 방식 : 일반적으로 원 ( circle ) 으로 표시하고, 고유한 번호 ( ID ) 나 이름 ( Label ) 을 붙인다.

쉽게 말하면, "점" 자체를 나타낸다.

 

▼간선 ( Edge )

정의 : 두 정점을 연결하는 선 ( 관계나 경로 )

종류 :

  • 무방향 간선 ( Undirected Edge ) : 양방향 관계 ( A 와 B 가 서로 연결됨 )
  • 방향 간선 ( Directed Edge ) : 한쪽 방향만 가능 ( A 에서 B 로 가는 관계 )
  • 가중치 간선 ( Weighted Edge ) : 비용이나 거리 같은 값이 붙은 간선 ( 지하철 거리 , 도로 시간 )

쉽게 말하면, "점과 점을 이어주는 선" 이다.

 

 

▼트리 ( Tree )

트리는 계층적 구조로 표현하는 자료구조이다.

노드 ( Node ) 와 간선 ( Edge ) 으로 이우러지며 부모 - 자식 관계를 가진다

 

▼노드 ( Node )

정의 : 트리의 구성 요소 ( 데이터를 담는 단위 )

하나의 노드는 데이터와 자식 노드( 들 )에 대한 참조를 가진다.

트리에서의 역할 구분

 

1. 루트 노드 ( Root Node )

  • 최상위에 있는 노드 ( 부모가 없다 )
  • 트리 전체의 시작점

 

2. 내부 노드 ( Internal Node )

  • 부모도 있고 자식도 있는 중간 단계 노드

 

3. 리프 노드 ( Leaf Node )

  • 더 이상 자식이 없는 노드 ( 끝 점 )

 

▼간선 ( Edge )

정의 : 노드와 노드를 연결하는 선

부모 - 자식 관계를 나타낸다.

항상 방향성이 있으며 ( 위에서 아래로 ) 순환이 없다.

 

 

 

비선형 자료구조를 사용하면 좋은 상황

1. 복잡한 관계 표현

  • 선형 자료구조 ( 배열 , 리스트 ) 는 순차적인 관계만 표현 가능
  • 현실 세계의 데이터는 계층 구조 ( 회사 조직도 , 폴더 구조 ) 또는 망 형태 ( SNS 친구 관계, 네트워크 ) 가 많다.
  • 이런 복잡한 관계를 자연스럽게 모델링하기 위해 필요하다.

 

2. 효율적인 탐색과 연산

  • 트리 : 이진 탐색 트리 ( BST ) 에서는 탐색 , 삽입 , 삭제가 평균적으로 빠르다
  • 힙 ( Heap ) : 우선순위 큐 구현 시 , 최대값 / 최소값을 빠르게 꺼낼 수 있다
  • 그래프 : 최단 경로 탐색 ( BFS ) 등 특정 문제를 빠르게 해결 가능

 

3. 자연스러운 계층적 데이터 저장

  • XML , JSON 같은 데이터 포맷은 트리 구조로 표현
  • 데이터베이스 인덱스 ( B - Tree ) , 운영체제 파일 시스템도 트리 기반이다.

 

4. 최적화된 문제 해결

  • 네비게이션 길찾기 - 그래프
  • 게임 AI 트리 ( 의사결정 트리, 상태 머신 ) - 트리
  • 압축 알고리즘 ( 허프만 트리 ) - 트리

 

 

정리

비선형 자료구조는 계층적 망형 관계를 표현

효율적인 탐색과 최적화 문제 해결을 위해 사용한다.

'⭐C Sharp > 15-6. 트리와 그래프' 카테고리의 다른 글

그래프 ( Graph )  (0) 2025.09.28
트리 ( Tree )  (0) 2025.09.28
'⭐C Sharp/15-6. 트리와 그래프' 카테고리의 다른 글
  • 그래프 ( Graph )
  • 트리 ( Tree )
DevHoChan
DevHoChan
맨땅에서 시작하는 코딩 도전
  • DevHoChan
    Debugging Life
    DevHoChan
  • 전체
    오늘
    어제
    • 분류 전체보기 (374)
      • 🕹️Game Life (1)
      • 🖥️Computer Science (5)
      • 📖TIL (141)
        • 🔥Projects (16)
        • 💡DevTips (5)
        • 🤔발생한 문제와 해결 (5)
        • 🔮Unity Graphics (5)
        • 🎤Interview (3)
        • ✅CodingTest (9)
      • 🚀Game Release (4)
      • 🧊Unity Basic (58)
        • 📌용어 사전 (1)
        • 에디터&인터페이스 (3)
        • 디버그 (1)
        • 라이프사이클 (4)
        • 게임오브젝트 (4)
        • 프리팹 (1)
        • 오브젝트풀링 (4)
        • 애트리뷰트 (2)
        • 트랜스폼 (4)
        • 물리&충돌 (1)
        • 프레임&델타타임 (4)
        • 코루틴&이벤트 (7)
        • 수학&보정함수 (3)
        • 디자인패턴 (9)
        • UGUI (3)
        • 벡터 ( Vector ) (3)
        • 씬 ( Scene ) (2)
        • 데이터 관리 (2)
      • ⭐C Sharp (99)
        • 📌용어 사전 (1)
        • 📌문법 사전 (6)
        • 메모리 관리 (3)
        • 00. 문법 (17)
        • 01. 변수 (3)
        • 02. 자료형 (2)
        • 03. 연산자 (6)
        • 04. 조건문 (2)
        • 05. 반복문 (2)
        • 06. 배열 (3)
        • 07. 메서드(함수) (7)
        • 08. 열거형 (3)
        • 09. 구조체 (2)
        • 10. 참조 (2)
        • 11. 객체 지향 (11)
        • 12. 델리게이트 (3)
        • 13. 디자인 패턴 (7)
        • 14. LINQ (1)
        • 📂▼자료구조 (2)
        • 15-1. 제네릭 (3)
        • 15-2. 배열 (4)
        • 15-3. 리스트 (2)
        • 15-4. 스택과 큐 (2)
        • 15-5. 딕셔너리 해시테이블 (2)
        • 15-6. 트리와 그래프 (3)
      • 📊Algorithm (16)
        • BigO (2)
        • 정렬 (4)
        • 셔플 (2)
        • 탐색 (6)
        • 최적화 (1)
      • 📝Game Design (16)
      • 🤖​AI Tools (12)
        • AI 리뷰 분석 (6)
        • Player2 (0)
        • 3D 모델링 (1)
        • 2D 스프라이트 (0)
        • 이미지 (2)
        • 사운드 (1)
        • 동영상 (1)
        • 문서 (1)
      • 🌍Network (6)
      • 🌱Github (11)
        • 기본 개념 (7)
        • 명령어 (1)
        • 도구 활용 (1)
      • ⚙️Visual Studio (5)
        • 🔧설치 및 환경설정 (2)
        • ⌨️HotKey (1)
        • 🚨디버깅 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    메모리관리
    algorithm
    자료형
    유니티
    GitHub
    객체지향
    CodingTest
    디자인패턴
    c#
    게임기획
    자료구조
    til
    게임디자인
    csharp
    OOP
    부트캠프
    unity
    문법
    기획
    gamedesign
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.4
DevHoChan
비선형 자료구조 ( Non - Linear )
상단으로

티스토리툴바