Back Tracking

2024. 11. 20. 18:20·Algorithm/내용 정리

 

❐ Description


백트랙킹 문제를 풀면서 면접 질문 대비 겸  개념을 정리해보자.

그리고 나만의 풀이 템플릿 까지 작성하여 라이브 코테도 준비하자.

 

 

 

 

 

❐ Back Tracking이란?


Back Tracking은 모든 가능한 해를 탐색하기 위해 DFS를 기반으로 하는 알고리즘 설계 기법이다.

주로 문제의 해를 구성하는 과정에서, 더 이상 유망하지 않은 해(조건에 부합하지 않거나 불가능한

경우)를 만나면 되돌아가(BackTrack) 다른 경로를 탐색한다. 이를 통해 불필요한 계산을 줄이고

효율적으로 문제를 해결할 수 있다.

 

  • DFS 기반 : 트리 또는 그래프 형태로 해를 구성하며, 깊이 우선 탐색을 진행한다.
  • Pruning(가지치기) : 조건에 맞지 않거나 유망하지 않은 경로를 탐색하지 않고 되돌아가는 과정.
  • 결과 탐색 : 모든 가능한 해를 탐색하거나, 하나의 해만 찾는 문제에도 사용된다.

BackTracking은 특히 탐색 공간이 클 때 가지치기를 통해 효율적으로 문제를 해결할 수 있는 강력한

기법이다. 문제의 제약 조건과 목표에 따라 Pruning 조건을 적절히 설계하는 것이 핵심이다.

 

 

 

 

❐ Sudo Code


public void backTracking(현재조건) {
    if (해결 조건 충족) {
        해를 저장;
        return;
    }
    
    for (가능한 선택 : 현재 상태에서의 선택지들) {
        if (유요한 선택인지 확인) {
            선택 적용;
            backTraking(다음 상태); // 재귀호출 
            상태 되돌리기; // BackTrack
        }
    }
}

 

 

 

 

 

❐ 장단점


1. 장점

  • 효율적 : 불필요한 탐색을 줄여 메모리와 시간을 절약
  • 직과적 : 재귀 구조를 활용하여 구현이 명확

2. 단점

  • 성능 한계 : 해 공간이 큰 경우에는 비효율적
  • 가지치기 전략이 약할 경우 많은 중복 계산 발생

 

 

 

 

 


'Algorithm > 내용 정리' 카테고리의 다른 글

Binary Search는 꼭 정렬된 배열에서만 사용해야 할까?  (0) 2025.01.06
Manacher 알고리즘  (0) 2024.12.15
Binary Search  (0) 2024.10.01
Dutch National Flag  (0) 2024.10.01
Insertion sort (삽입 정렬)  (0) 2024.09.29
'Algorithm/내용 정리' 카테고리의 다른 글
  • Binary Search는 꼭 정렬된 배열에서만 사용해야 할까?
  • Manacher 알고리즘
  • Binary Search
  • Dutch National Flag
gilbert9172
gilbert9172
gilbert9172 님의 블로그 입니다.
  • gilbert9172
    バックエンド
    gilbert9172
  • 전체
    오늘
    어제
    • All Categories (207)
      • 우테코 7기 (21)
        • 1주차 (8)
        • 2주차 (5)
        • 3주차 (6)
      • Langauge (6)
        • Java (3)
        • Kotlin (3)
      • Back-End (13)
        • SpringBoot (1)
        • Trouble Shooting (0)
        • Setup & Configuration (1)
        • SQL (3)
        • Redis (8)
      • Architecture (6)
        • Multi Module (1)
        • DDD (5)
      • CS (30)
        • Data Structure (6)
        • Operating System (0)
        • Network (12)
        • Database (10)
        • Design Pattern (2)
      • Algorithm (78)
        • 내용 정리 (18)
        • 문제풀이 (60)
      • DevOps (6)
        • AWS (5)
        • Git (1)
      • Front-End (1)
        • Trouble Shooting (1)
      • Project (6)
        • 페이스콕 (6)
      • Book (39)
        • 친절한 SQL 튜닝 (9)
        • 데이터 중심 애플리케이션 설계 (14)
        • 이벤트 기반 마이크로서비스 구축 (6)
        • Spring Batch docs (10)
        • Quartz docs (0)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

    부분단조성
    sliding-window
    binarysearch
    Two-Pointer
    Back-Tracking
    오블완
    greedy
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.2
gilbert9172
Back Tracking
상단으로

티스토리툴바