그래프 ( Graph )

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

그래프 ( Graph )

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

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

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

 

 

▼정점 ( Vertex , Node )

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

예시 : 

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

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

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

 

 

▼간선 ( Edge )

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

종류 :

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

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

 

 

문법

▼인접 리스트 방식

Dictionary<int, List<int>> graph = new Dictionary<int, List<int>>();

 

 

▼정점 추가

graph[1] = new List<int> { 2, 3 };
graph[2] = new List<int> { 1, 4 };
graph[3] = new List<int> { 1 };
graph[4] = new List<int> { 2 };

 

 

 

예시 코드

▼DFS ( 깊이 우선 탐색 )

void DFS(int start, Dictionary<int, List<int>> graph, HashSet<int> visited)
{
    if (visited.Contains(start)) return;

    Console.WriteLine(start);
    visited.Add(start);

    foreach (var neighbor in graph[start])
    {
        DFS(neighbor, graph, visited);
    }
}

 

▼실행

var visited = new HashSet<int>();
DFS(1, graph, visited);

 

 

 

주의할 점

순환 ( Cycle ) 여부 : 그래프틑 순환이 존재할 수 있으므로 방문 여부 체크는 필수이다.

방향성 : 방향 그래프 ( Directed Graph ) 인지 무방향 그래프 ( Undirected Graph ) 인지 구분이 필요하다.

가중치 ( Weight ) : 간선에 비용이 붙을 수 있다. - 알고리즘 ( 다익스트라 , 크루스칼 등 ) 에서 중요하다.

저장 방식 : 인접 리스트 ( 메모리 효율적 ) vs 인접 행결 ( 연산 단순하지만 메모리 소모 큼 ) 선택 필요

 

 

정리

그래프는 정점과 간선으로 이루어진 비선형 자료구조로 개체 간의 복잡한 관계를 표현할 수 있다.

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

트리 ( Tree )  (0) 2025.09.28
비선형 자료구조 ( Non - Linear )  (0) 2025.09.28
'⭐C Sharp/15-6. 트리와 그래프' 카테고리의 다른 글
  • 트리 ( Tree )
  • 비선형 자료구조 ( Non - Linear )
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)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

  • hELLO· Designed By정상우.v4.10.4
DevHoChan
그래프 ( Graph )
상단으로

티스토리툴바