탐색 알고리즘 ( Search Algorithms )

2025. 11. 10. 00:43·📊Algorithm/탐색

탐색 알고리즘 ( Search Algorithms )

C# 에서 탐색 알고리즘은 데이터 안에서 원하는 값을 찾는 방법이다.

탐색은 정렬 여부 / 탐색 범위 / 구조 형태 ( 리스트 , 트리 , 그래프 등 ) 에 따라 여러 가지로 나뉜다.

 

 

1. 기본 탐색 알고리즘 ( 배열 , 리스트 )

데이터가 정렬되어 있는지 여부에 따라 달라진다.

 

1-1. 선형 탐색 ( Linear Search )

  • 하나씩 순서대로 비교하는 가장 단순한 방법
  • 정렬되어 있지 않아도 사용 가능
  • BigO : O(n)
int LinearSearch(int[] arr, int target)
{
    for (int i = 0; i < arr.Length; i++)
        if (arr[i] == target) return i;
    return -1;
}

 

 

1-2. 이진 탐색 ( Binary Search )

  • 정렬된 배열에서 중간값을 기준으로 탐색
  • 중간값보다 작으면 왼쪽 , 크면 오른쪽 절반만 탐색
  • BigO : O(log n)
int BinarySearch(int[] arr, int target)
{
    int left = 0, right = arr.Length - 1;

    while (left <= right)
    {
        int mid = (left + right) / 2;
        if (arr[mid] == target) return mid;
        else if (arr[mid] < target) left = mid + 1;
        else right = mid - 1;
    }
    return -1;
}

C# 에서는 Array.BinarySearch( ) 메서드가 이미 구현되어 있다.

 

 

2. 트리 탐색 ( Tree Search )

트리 구조에서 노드를 탐색할 때 사용한다.

 

2-1. 깊이 우선 탐색 ( DFS , Depth-First Search )

  • 루트에서 시작해서 끝까지 탐색 후 되돌아온다
  • 스택 ( Stack ) 또는 재귀 ( Recursion ) 로 구현한다
  • BigO : O(V + E) (정점 + 간선)
void DFS(Node node)
{
    if (node == null) return;
    Console.WriteLine(node.value);
    foreach (var child in node.children)
        DFS(child);
}

 

 

2-2. 너비 우선 탐색 ( BFS , Breadth-First Search )

  • 가까운 노드부터 차례대로 탐색한다
  • 큐 ( Queue ) 사용한다
  • BigO : O(V + E)
void BFS(Node start)
{
    Queue<Node> q = new Queue<Node>();
    q.Enqueue(start);

    while (q.Count > 0)
    {
        Node node = q.Dequeue();
        Console.WriteLine(node.value);
        foreach (var child in node.children)
            q.Enqueue(child);
    }
}

 

 

3. 그래프 탐색 ( Graph Search )

그래프는 트리보다 일반화된 구조로 DFS / BFS 가 그대로 사용된다.

  • DFS : 백트래킹 , 미로 탐색 등에 자주 사용
  • BFS : 최단 거리 탐색에 자주 사용 ( A* 의 기본 원리 )

 

'📊Algorithm > 탐색' 카테고리의 다른 글

Dijkstra & A-Star  (0) 2025.11.20
Dijkstra 다익스트라  (0) 2025.11.20
너비 우선 탐색 ( BFS )  (0) 2025.11.14
깊이 우선 탐색 ( DFS )  (0) 2025.11.14
A-Star ( A* )  (0) 2025.11.10
'📊Algorithm/탐색' 카테고리의 다른 글
  • Dijkstra 다익스트라
  • 너비 우선 탐색 ( BFS )
  • 깊이 우선 탐색 ( DFS )
  • A-Star ( A* )
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)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

  • hELLO· Designed By정상우.v4.10.4
DevHoChan
탐색 알고리즘 ( Search Algorithms )
상단으로

티스토리툴바